1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 【开发】一篇文章精通Docker | 狂神Docker学习笔记 | Docker容器基础命令 | Doc

【开发】一篇文章精通Docker | 狂神Docker学习笔记 | Docker容器基础命令 | Doc

时间:2020-12-20 00:08:14

相关推荐

【开发】一篇文章精通Docker | 狂神Docker学习笔记 | Docker容器基础命令 | Doc

文章目录

docker 的常用命令帮助命令镜像命令容器命令常用其他命令 可视化portainer Docker容器镜像原理讲解Commit镜像容器数据卷什么是容器数据卷具名和匿名挂载volume 卷命令通过 -v 容器内路径: ro / rw 改变读写权限初始Dockerfile数据卷容器 DockerFileDockerFile 的创建发布镜像 Docker网络docker0

docker 的常用命令

帮助命令

docker version # 显示docker的版本信息docker info # docker详细信息docker 命令 --help# 万能命令

镜像命令

docker images 查看所有本地主机上的镜像

[root@mushan /]# docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEhello-world latest d1165f221234 5 months ago 13.3kB#解释REPOSITORY镜像仓库源TAG镜像的标签IMAGE ID镜像的IDCREATED镜像创建的时间SIZE镜像的大小#可选项(可混合使用)-a, --all 列出所有镜像-q, --quiet 只显示镜像的id

docker search 搜索镜像

➜ mushan docker search mysqlNAMEDESCRIPTION STARSOFFICIAL AUTOMATEDmysql MySQL is a widely used, open-source relation… 11308[OK] mariadb MariaDB Server is a high performing open sou… 4294[OK] mysql/mysql-serverOptimized MySQL Server Docker images. Create… 838 [OK]#解释NAME镜像仓库源的名称DESCRIPTION镜像描述START点赞量OFFICIAL是否 docker 官方发布AUTOMATED自动构建#可选项, 通过搜索来过滤--filter=STARS=3000# 搜索镜像STARS大于3000

docker pull 下载镜像

# 下载镜像 docker pull 镜像名[:tag](版本默认为最新)[root@mushan /]# docker pull mysqlUsing default tag: latest# 如果不写tag, 默认为latest(最后一个, 最新版)latest: Pulling from library/mysqle1acddbe380c: Pull complete # 分层下载, docker image的核心 联合文件系统bed879327370: Pull complete 03285f80bafd: Pull complete ccc17412a00a: Pull complete 1f556ecc09d1: Pull complete adc5528e468d: Pull complete 1afc286d5d53: Pull complete 6c724a59adff: Pull complete 0f2345f8b0a3: Pull complete c8461a25b23b: Pull complete 3adb49279bed: Pull complete 77f22cd6c363: Pull complete Digest: sha256:d45561a65aba6edac77be36e0a53f0c1fba67b951cb728348522b671ad63f926# 签名(防伪)Status: Downloaded newer image for mysql:latestdocker.io/library/mysql:latest# 真实地址# 等价于docker pull mysqldocker pull docker.io/library/mysql:latest# 下载特定版本[root@mushan /]# docker pull mysql:5.75.7: Pulling from library/mysql# tag == 5.7e1acddbe380c: Already exists # 前面已经安装了mysql最新版, 5.7版本有重复内容, 共用无需下载bed879327370: Already exists 03285f80bafd: Already exists ccc17412a00a: Already exists 1f556ecc09d1: Already exists adc5528e468d: Already exists 1afc286d5d53: Already exists 4d2d9261e3ad: Pull complete ac609d7b31f8: Pull complete 53ee1339bc3a: Pull complete b0c0a831a707: Pull complete Digest: sha256:7cf2e7d7ff876f93c8601406a5aa17484e6623875e64e7acc71432ad8e0a3d7eStatus: Downloaded newer image for mysql:5.7docker.io/library/mysql:5.7#查看本地镜像➜ / docker images REPOSITORY TAG IMAGE ID CREATED SIZEmysql 5.7 6c20ffa54f86 4 days ago448MBmysql latest 5a4e492065c7 4 days ago514MBhello-world latest d1165f221234 5 months ago 13.3kB# 此时同时存在 mysql:latset 和 mysql:5.7 两个版本

docker rmi 删除镜像

# 通过ID删除docker rmi -f ID#删除指定容器docker rmi -f ID ID ID#删除多个指定容器docker rmi -f $(docker images -aq)#删除全部容器

➜ mushan docker rmi -f 6c20ffa54f86Untagged: mysql:5.7Untagged: mysql@sha256:7cf2e7d7ff876f93c8601406a5aa17484e6623875e64e7acc71432ad8e0a3d7eDeleted: sha256:6c20ffa54f8674203e91e3225e489aa505fa04b8d482954a8b6d7414842c6de4Deleted: sha256:7ecf077dd9d6725f0e594b9cd5eb214ad1b3764fa75bf5940ab08b05b8bae184Deleted: sha256:c28edab85681de37f9d2a75dde941a20d2e1ac6e4efb7dee391913d3ec722fefDeleted: sha256:6c11b187da1ecb65ce10b25f54354f3515ce9d26fabcd859cdb43dbd625df907Deleted: sha256:d0dfc5be0883ed4af9f642a8e4f2312a93c4241ec8e89f22219b0f0a0d26c8d3# 只删除与 mysql:latest 不共用的内容# 删除本地全部docker镜像➜ mushan docker rmi -f $(docker images -aq)$: 表示把括号里面的内容作为参数传入docker images -aq: 表示查出本地所有的镜像ID➜ mushan docker images # 此时镜像列表为空 REPOSITORY TAG IMAGE ID CREATED SIZE

# 通过命名删除 docker rmi -f 镜像名[:tag]# 删除指定容器单个版本docker rmi -f $(docker images mysql -aq) # 删除指定容器全部版本docker rmi -f 镜像名[:tag] 镜像名[:tag] # 删除多个指定容器单个版本...同等嵌套类似

inspect 查看镜像数据源

docker inspect 容器ID

容器命令

说明: 有了镜像之后才可以创建容器, linux, 下载一个centos镜像测试学习

docker pull centos

新建容器并启动

docker run[可选参数] image# 参数说明--name="Name"容器名字 name1 name2, 用来区分容器-d以后台方式运行-it使用交互方式运行, 进入容器查看内容-i允许你对容器内的标准输入 (STDIN) 进行交互。-t在新容器内指定一个伪终端或终端。-p(小写) 指定容器的端口 -p 8080:8080-P(大写) 随机指定端口

#-p(小写) 格式: -p 主机端口:容器端口#(常用)-p 容器端口容器端口

!测试# 启动并进入容器➜ / docker run -it centos /bin/bash[root@9e8f5d24331a /]# lsbin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var# 从容器中退回主机exit➜ / lsbin boot dev etc home lib lib64 lost+found mnt opt proc root run sbin srv sys tmp usr var

列出运行的容器

docker ps列出当前正在运行的容器完整信息docker ps -a列出历史运行过的容器完整信息docker ps -n=?列出?个历史运行过的容器完整信息docker ps -q列出当前正在运行的容器编号#[可选项]可以混合使用

# 测试➜ / docker psCONTAINER ID IMAGECOMMAND CREATEDSTATUSPORTSNAMES9b8c37b20ae6 centos "/bin/bash" 35 minutes ago Up 22 minutes vigilant_thompson# 输出详情介绍CONTAINER ID: 容器 ID。IMAGE: 使用的镜像。COMMAND: 启动容器时运行的命令。CREATED: 容器的创建时间。STATUS: 容器状态。PORTS: 容器的端口信息和使用的连接类型(tcp\udp)。NAMES: 自动分配的容器名称。# 7种状态created(已创建)restarting(重启中)running / Up(运行中)removing(迁移中)paused(暂停)exited(停止)dead(死亡)

退出容器

exit# 直接容器停止并退出ctrl + p + q# 退出, 但不停止容器

启动和停止容器操作

docker start 容器id# 启动容器docker restart 容器id# 重启容器docker stop 容器id# 停止当前正在运行的容器docker kill 容器id# 强制停止当前正在运行容器

导出和导入容器快照

导出容器快照: docker export 容器id > 文件名docker export 1e560fca3906 > centos.tar导出容器快照: cat docker /文件名 | docker import - test/镜像名:[:tag]cat docker/centos.tar | docker import - test/ubuntu:v1#此外,也可以通过指定 URL 或者某个目录来导入,例如:docker import /exampleimage.tgz example/imagerepo

删除容器

docker rm 容器ID# 删除指定容器docker rm -f $(docker ps -aq) # 删除全部容器(-f 表强制 可删除正在运行容器)docker ps -a -q|xargs docker rm # 删除全部容器

常用其他命令

后台启动容器:

# 通过-d 方式创建容器 docker run -d 镜像名docker run -d centos# 问题docker ps. 发现 centos 停止了# 常见的坑, docker 容器使用后台运行, 就必须要有一个前台进程, 如果没有前台进程, 只在后台运行, docker发现没有应用, 就会自动停止nginx, 容器启动后, 发现自己没有提供服务, 就会立刻停止(自杀), 就是没有程序了一般采用 -itd 来后台启动

查看日志

docker logs -f -t --since="时间戳" --tail=查看个数 容器id# 例: docker logs -f -t --since="-04-15T02:14:00" --tail=1000 9c03ea2c# 参数解释-f:动态实时显示-t:显示日志生成时的时间戳--since:从指定时间戳开始(默认中时区,即在北京东八区的时间戳上减去8小时)--tail / -n:显示最后的条数# 测试:# 自己编写一端shell脚本docker run -d centos /bin/bash -c "while true; do echo mushan;sleep 1;done"

查看容器中进程信息

# top命令➜ / docker top 5ba11c251c85UID PID PPIDC STIMETTYTIMEroot 2343023399 0 16:27? 00:00:00 root 2703223430 0 16:52? 00:00:00 # 解释UID用户IDPID进程IDPPID父进程ID

查看镜像源数据

# inspect命令docker inspect 容器ID

[{"Id": "5ba11c251c8508d2519c67e708fce5a8e2ccbbd753cc89245554bae37f5b82d7","Created": "-08-22T16:27:38.5583555Z","Path": "/bin/bash","Args": ["-c","while true; do echo mushan;sleep 1;done"],"State": {"Status": "running","Running": true,"Paused": false,... ... ... ... ... .}... ... ... ... ... ...]

进入当前正在运行的容器

# 容器通常使用后台方式运行, 有时需要进入容器, 修改一些配置# 方式一:(进入容器后开启一个新的终端, 可以在里面操作)#docker exec -it 容器id bashShell➜ / docker exec -it 5ba11c251c85 /bin/bash# 方式二:#docker attach 容器id(进入容器正在执行的终端, 不会启动新的进程!)➜ / docker attach 5ba11c251c85正在执行当前的代码...

从容器内拷贝文件到主机

docker cp 容器id:容器内路径 目的主机路径容器id 使用 docker ps -a查看(即是容器关闭了, 只要容器还在, 就可以获取内容)转到主机# 测试:docker cp 872613da391c:/home/mushan.cpp /home➜ /home lsdocker_ceshi.txt mushan mushan.cpp(这个就是拷贝过来的内容)

可视化

portainerRancher ( CI/CD 再用)

portainer

什么是 portainer?

Docker图形化界面管理工具 ! 提供一个后台面板操作 !

安装运行:

➜ / docker run -d -p 8088:9000 \--restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer

Unable to find image 'portainer/portainer:latest' locallyBlatest: Pulling from portainer/portainer94cfa856b2b1: Pull complete 49d59ee0881a: Pull complete a2300fd28637: Pull complete Digest: sha256:fb45b43738646048a0a0cc74fcee2865b69efde857e710126084ee5de9be0f3fStatus: Downloaded newer image for portainer/portainer:latest7502fee2a1282c2302530f18b07ec2f52540eb3407cd2d21a07b0702111250f9

访问测试 : 外网 : 8088

浏览器查看: http://192.168.138.129:8088/

访问成功!

Username: adminPassword: 12345678

进入本地仓库

Docker容器镜像原理讲解

跳过… baidu

Commit镜像

格式

docker commit 提交容器成为一个新的副本# 命令和git原理类似docker commit -m="提交的描述信息" -a="作者" 容器id 目标镜像名:[tag]

实战测试

# 启动一个默认的tomcat# 官方的镜像中, webapps 中默认是没有文件的# webapps.dist 中 拷贝内容给 webapps.# 此时我在容器里面在官方tomcat的基础上发了改变# 我认为我修改后的容器更加方便, 想把它打包成容器.

➜ ~ docker psCONTAINER ID IMAGECOMMAND CREATEDSTATUSPORTS NAMESb09303c24d37 tomcat "catalina.sh run" 14 minutes ago Up 14 minutes 0.0.0.0:8080->8080/tcp, :::8080->8080/tcp funny_einstein➜ ~ docker commit -a="mushan" -m="add webapps app cp webapps.dist" b09303c24d37 tomcat_mushan:1.0sha256:c24575315327b17d7abd6d8f9904f4721e10098f9b6efda0903855531d0961d1➜ ~ docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEtomcat_mushan 1.0 c24575315327 8 seconds ago 673MBtomcatlatest 266d1269bb29 6 days ago668MBnginx latest dd34e67e3371 8 days ago133MBportainer/portainer latest 580c0e4e98b0 5 months ago 79.1MBcentoslatest 300e315adb2f 8 months ago 209MBkibana7.6.2f70986bc5191 17 months ago 1.01GBelasticsearch 7.6.2f29a1ee41030 17 months ago 791MB➜ ~ # 这里出现了我们打包提交成功的 tomcat_mushan

对比 tomcat 和 tomcat_mushan

# tomcat_mushan (共11层)... ... ... ...省略"RootFS":"sha256:c2ddc1bc2645ab5d982c60434d8bbc6aecee1bd4e8eee0df7fd08c96df2d58bb","sha256:62d14713f2e98841ec3927e3ab611b13e414a21fb82fc0e604a9008ac53e45dc","sha256:1235daf38153d083ae5b4f605acc54f9401143b5fbd033801ba373a8cfb04845","sha256:7d890913ab6955350bdd25d04c60dd444db13890c401cbcdc8e00e9bd29c90fc","sha256:c2e2307780ac2fa0d39cec874c4545156da890c1bcc42b3259114ac29bb598f1","sha256:75f6a0e6e441cd3d74125443fc73eb26bf9ceb557b269b25bddaa2ef459227f7","sha256:b19f17003e5ae07f7aba99f95736627aaa1ff3c92832f7d698dc6b138bcf","sha256:2dad09b8a57e12408adc0366cbd2a642eaab1c82bbfb2b442245928b60d337f1","sha256:83a14c3e974e700768197a3061f840618a924d3154fcb338a85b6da5fd4eb886","sha256:19f8bd134bcf7c5870f8294b1d3bba4c970d0b622772865e44d200d248ed2676","sha256:997ad98329327bc8cc90838a8804a5ad4c93d5286e03decf2715bbb035e4a5a1"... ... ... ...省略# tomcat (共10层)... ... ... ...省略"RootFS":"sha256:c2ddc1bc2645ab5d982c60434d8bbc6aecee1bd4e8eee0df7fd08c96df2d58bb","sha256:62d14713f2e98841ec3927e3ab611b13e414a21fb82fc0e604a9008ac53e45dc","sha256:1235daf38153d083ae5b4f605acc54f9401143b5fbd033801ba373a8cfb04845","sha256:7d890913ab6955350bdd25d04c60dd444db13890c401cbcdc8e00e9bd29c90fc","sha256:c2e2307780ac2fa0d39cec874c4545156da890c1bcc42b3259114ac29bb598f1","sha256:75f6a0e6e441cd3d74125443fc73eb26bf9ceb557b269b25bddaa2ef459227f7","sha256:b19f17003e5ae07f7aba99f95736627aaa1ff3c92832f7d698dc6b138bcf","sha256:2dad09b8a57e12408adc0366cbd2a642eaab1c82bbfb2b442245928b60d337f1","sha256:83a14c3e974e700768197a3061f840618a924d3154fcb338a85b6da5fd4eb886","sha256:19f8bd134bcf7c5870f8294b1d3bba4c970d0b622772865e44d200d248ed2676"... ... ... ...省略# 可以发现 tomcat 和 tomcat_mushan 仅仅在tomcat的基础上多加了最后一层

启动 tomcat_mushan 试试效果:

➜ ~ docker run -it -p 8081:8081 tomcat_mushan:1.0

tomcat_mushan:

tomcat:

容器数据卷

什么是容器数据卷

docker的理念回顾

例: 将一个MySQL容器打包成一个镜像 !

当删除这个这个容器的时候, 里面存储的数据文件就会丢失 ! (删库跑路)

此时这种情况会很危险

需求: 数据持久化

需求: MySQL数据可以存储在本地 !

为了实现这一需求, 容器之间可以由一个数据共享技术 (卷技术) ! Docker 容器中产生的数据, 同步到本地

如何使用卷 : -v 挂载

docker run -it -v 主系统的一个路径:容器中的一个路径# centos容器为例docker run -it -v /home/ceshi:/home centos /bin/bash# 此时 主文件系统和容器文件系统 挂载的路径将会互通无论容器是否处于运行状态, 无论是哪一路径下内容发生改变, 另一方都会同时发生相同的变化容器和主系统两端一直是一致互通的

具名和匿名挂载

-v 容器内路径docker run -d -P --name nginx01 -v /etc/nginx nginx(匿名)# 匿名挂载: 只写容器内路径, 不写容器外路径docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx(具名)# 具名挂载: 通过 -v 卷名:容器内路径

volume 卷命令

docker volume --helpCommands:createCreate a volumeinspectDisplay detailed information on one or more volumeslsList volumesprune Remove all unused local volumesrmRemove one or more volumes

➜ / docker volume ls DRIVER VOLUME NAMElocal4b13ad4d9594573dc7d7b2cc944ae56b838c3b437aa3735377fb0f25c25cb526locald205865d4dcd5d50c97c09f532d580350f65180f2d1b3f48b425a71ea9ed0135localjuming-nginx# 前两个分别是mysql 和 nginx 的匿名挂载, 第三个是 nginx 的具名挂载

➜ / docker volume inspect juming-nginx[{"CreatedAt": "-08-27T07:27:06Z","Driver": "local","Labels": null,"Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data","Name": "juming-nginx","Options": null,"Scope": "local"}]

➜ / docker volume inspect d205865d4dcd5d50c97c09f532d580350f65180f2d1b3f48b425a71ea9ed0135[{"CreatedAt": "-08-27T06:49:28Z","Driver": "local","Labels": null,"Mountpoint": "/var/lib/docker/volumes/d205865d4dcd5d50c97c09f532d580350f65180f2d1b3f48b425a71ea9ed0135/_data","Name": "d205865d4dcd5d50c97c09f532d580350f65180f2d1b3f48b425a71ea9ed0135","Options": null,"Scope": "local"}]

所有没设定挂载路径的卷, 默认都在路径/var/lib/docker/volumes/挂载名/_data_路径下

挂载名, 如果是具名挂载就是以-v后的子串命名, 否则为匿名挂载以生成的一段规律字串命名

通过 -v 容器内路径: ro / rw 改变读写权限

# 通过 -v 容器内路径: ro / rw 改变读写权限(默认是rw)ro:readonly#只读rw:readwrite#读写docker run -d -P --name nginx01 -v juming-nginx:/etc/nginx:ro nginxdocker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx# 一旦设置了容器权限, 容器对挂载出来的内容就有了限定# 设定为 ro 时, 这个路径将只能通过宿主机来操作, 容器内部是无法操作的

初始Dockerfile

Dockerfile: 用来构建 docker 镜像的构建文件 ! 命令脚本 !

通过这个脚本可以生成镜像, 镜像是一层一层的, 脚本一个个的命令, 每个命令都是一层

创建路径 mkdir /home/docker-test-volume 创建编辑文件vim dockerfile1

# 自定义DockerfileFORM centos# 以centos为基础VOLUME ["volume01", "volume02"]# 挂载目录(这里是匿名挂载)CMD echo "----end----"# 完成后输出"----end----"CMD /bin/bash# 默认进入使用 bash 控制台

➜ / docker build -f /home/docker-test-volume/dockerfile1 -t mushan/centos:1.0 .# 参数说明build命令构建镜像-f通过什么脚本文件构建(脚本路径)-t生成: 镜像名:[tag].当前目录# 返回内容:Sending build context to Docker daemon 2.048kBStep 1/4 : FROM centos---> 300e315adb2fStep 2/4 : VOLUME ["volume01", "volume02"]---> Running in add71936df4aRemoving intermediate container add71936df4a---> f005f45db9deStep 3/4 : CMD echo "----end----"---> Running in 01b8f543c1bcRemoving intermediate container 01b8f543c1bc---> 0ef638078484Step 4/4 : CMD /bin/bash---> Running in 89be86ba72c5Removing intermediate container 89be86ba72c5---> 37a96d02edb1Successfully built 37a96d02edb1Successfully tagged mushan/centos:1.0# 成功生成镜像➜ docker-test-volume docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEmushan/centos 1.0 37a96d02edb1 6 minutes ago 209MB

数据卷容器

通过--volumes-from命令, 实现两个容器之间的挂载与数据同步 (伪同步)

测试:

创建三个centos镜像

docker run -it --name="centos01" mushan/centos:1.0 /bin/bashdocker run -it --name="centos02" --volumes-from centos01 centos:latest /bin/bashdocker run -it --name="centos03" --volumes-from centos01 centos:latest /bin/bash# 规则1: 必须有一个容器与宿主机某路径同步挂载# 规则2: 仅仅同步与宿主机挂载的路径--volumes-from 命令只不过是把centos01 与宿主机挂载的内容cp了进去# 三个容器同时同步宿主机挂载路径同步成功后...

# 进入宿主机挂载路径, 发现内容是同步的➜ _data pwd/var/lib/docker/volumes/4883e91e3f0583ba8e03081644542386ef685b28bd34bcb9c1e86fb3566dec7c/_data➜ _data lsmushan# 把路径删除/4883e91e3f0583ba8e03081644542386ef685b28bd34bcb9c1e86fb3566dec7crm -rf 4883e91e3f0583ba8e03081644542386ef685b28bd34bcb9c1e86fb3566dec7c# 此时无论在哪个容器中创建文件/文件夹都会失败[root@6dd479046fcf volume01]# mkdir mushanmkdir: cannot create directory 'mushan': No such file or directory# 此时就算把文件夹创建回来也没有用

DockerFile

Dockerfile: 用来构建 docker 镜像的构建文件 ! 命令脚本 !

构建步骤

编写一个dockerfile文件docker build 构建成为一个镜像docker run 运行镜像docker push 发布镜像( Docker Hub , 阿里云镜像仓库)

# centos-8官方dockerfileFROM scratchADD centos-8-x86_64.tar.xz /LABEL \org.label-schema.schema-version="1.0"\org.label-schema.name="CentOS Base Image"\org.label-schema.vendor="CentOS"\org.label-schema.license="GPLv2"\org.label-schema.build-date="2004"CMD ["/bin/bash"]

DockerFile 的创建

FROM# 指定基础镜像, 一切从这里开始构建MAINTAINER# 指定维护者信息(姓名 + 邮箱)RUN# 运行一些内容, 可以echo输出一些东西COPY# 将文件拷贝到镜像中ADD# COPY文件, 会自动解压WORKDIR# 设置默认工作目录VOLUME# 设置卷, 挂载主机目录EXPOSE# 暴露端口CMD# 指定容器启动时要运行的命令(只有最后一个会生效, 会被覆盖)ENTRYPOINT# 指定容器启动时要运行的命令, 可追加命令ONBUILD# 被继承时触发指令ENV# 创建时设置环境变量CMD: 命令可以用于默认设置, 比如启动方式/bin/bash为默认, 但是如果用户想通过其他的方式启动, 默认失效

发布镜像

DockerHub

登录DockerHub

docker login 用户名password: 输入密码

tag命令修改镜像名(添加一个标签)

docker tag 本地镜像名[:tag] 要修改的镜像名[:tag]# 一般使用 mushan/镜像名 命名

上传镜像

docker push 修改后的镜像名[:tag]

Docker网络

docker0

ip addr# 查看ip

【开发】一篇文章精通Docker | 狂神Docker学习笔记 | Docker容器基础命令 | Docker-主机挂载 | 创建 发布Docker镜像 | 配置Dockerfile文件

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。