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

docker 的常用命令

帮助命令

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

镜像命令

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

[root@mushan /]	# docker images
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
hello-world   latest    d1165f221234   5 months ago   13.3kB

#	解释
REPOSITORY	镜像仓库源
TAG			镜像的标签
IMAGE ID	镜像的ID
CREATED		镜像创建的时间
SIZE		镜像的大小

#	可选项(可混合使用)
-a, --all	 列出所有镜像
-q, --quiet	 只显示镜像的id

docker search 搜索镜像

➜  mushan docker search mysql
NAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                             MySQL is a widely used, open-source relation…   11308     [OK]       
mariadb                           MariaDB Server is a high performing open sou…   4294      [OK]       
mysql/mysql-server                Optimized 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 mysql     
Using default tag: latest		# 如果不写tag, 默认为latest(最后一个, 最新版)
latest: Pulling from library/mysql
e1acddbe380c: 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:latest
docker.io/library/mysql:latest	# 真实地址
# 等价于
docker pull mysql
docker pull docker.io/library/mysql:latest

# 下载特定版本
[root@mushan /]# docker pull mysql:5.7
5.7: Pulling from library/mysql		# tag == 5.7
e1acddbe380c: 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:7cf2e7d7ff876f93c8601406a5aa17484e6623875e64e7acc71432ad8e0a3d7e
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7

#查看本地镜像
➜  / docker images        
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
mysql         5.7       6c20ffa54f86   4 days ago     448MB
mysql         latest    5a4e492065c7   4 days ago     514MB
hello-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 6c20ffa54f86
Untagged: mysql:5.7
Untagged: mysql@sha256:7cf2e7d7ff876f93c8601406a5aa17484e6623875e64e7acc71432ad8e0a3d7e
Deleted: sha256:6c20ffa54f8674203e91e3225e489aa505fa04b8d482954a8b6d7414842c6de4
Deleted: sha256:7ecf077dd9d6725f0e594b9cd5eb214ad1b3764fa75bf5940ab08b05b8bae184
Deleted: sha256:c28edab85681de37f9d2a75dde941a20d2e1ac6e4efb7dee391913d3ec722fef
Deleted: sha256:6c11b187da1ecb65ce10b25f54354f3515ce9d26fabcd859cdb43dbd625df907
Deleted: 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 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
# 从容器中退回主机
exit
➜  / ls
bin  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 ps
CONTAINER ID   IMAGE     COMMAND       CREATED          STATUS          PORTS     NAMES
9b8c37b20ae6   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 http://example.com/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="2019-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 5ba11c251c85
UID            PID            PPID          C       STIME      TTY      TIME     
root           23430          23399         0       16:27      ?        00:00:00 
root           27032          23430         0       16:52      ?        00:00:00 

# 解释
UID		用户ID
PID		进程ID
PPID	父进程ID

查看镜像源数据

# inspect命令
docker inspect 容器ID
[
    {
        "Id": "5ba11c251c8508d2519c67e708fce5a8e2ccbbd753cc89245554bae37f5b82d7",
        "Created": "2021-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 ls
docker_ceshi.txt  mushan  mushan.cpp(这个就是拷贝过来的内容)

可视化

  • portainer
  • Rancher ( 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' locally
Blatest: Pulling from portainer/portainer
94cfa856b2b1: Pull complete 
49d59ee0881a: Pull complete 
a2300fd28637: Pull complete 
Digest: sha256:fb45b43738646048a0a0cc74fcee2865b69efde857e710126084ee5de9be0f3f
Status: Downloaded newer image for portainer/portainer:latest
7502fee2a1282c2302530f18b07ec2f52540eb3407cd2d21a07b0702111250f9

访问测试 : 外网 : 8088

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

在这里插入图片描述

访问成功!

Username: admin
Password: 12345678

进入本地仓库

在这里插入图片描述

Docker容器镜像原理讲解

跳过… baidu

Commit镜像

格式

docker commit 提交容器成为一个新的副本

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

实战测试

# 启动一个默认的tomcat
# 官方的镜像中, webapps 中默认是没有文件的
# webapps.dist 中 拷贝内容给 webapps.
# 此时我在容器里面在官方tomcat的基础上发了改变
# 我认为我修改后的容器更加方便, 想把它打包成容器.
➜  ~ docker ps                                    
CONTAINER ID   IMAGE     COMMAND             CREATED          STATUS          PORTS                                       NAMES
b09303c24d37   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
.0
sha256:c24575315327b17d7abd6d8f9904f4721e10098f9b6efda0903855531d0961d1
➜  ~ docker images
REPOSITORY            TAG       IMAGE ID       CREATED         SIZE
tomcat_mushan         1.0       c24575315327   8 seconds ago   673MB
tomcat                latest    266d1269bb29   6 days ago      668MB
nginx                 latest    dd34e67e3371   8 days ago      133MB
portainer/portainer   latest    580c0e4e98b0   5 months ago    79.1MB
centos                latest    300e315adb2f   8 months ago    209MB
kibana                7.6.2     f70986bc5191   17 months ago   1.01GB
elasticsearch         7.6.2     f29a1ee41030   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:b19f17003e5ae07f7aba99f95736627aaa1ff3c92832f7d6920158dc6b138bcf",
 "sha256:2dad09b8a57e12408adc0366cbd2a642eaab1c82bbfb2b442245928b60d337f1",
 "sha256:83a14c3e974e700768197a3061f840618a924d3154fcb338a85b6da5fd4eb886",
 "sha256:19f8bd134bcf7c5870f8294b1d3bba4c970d0b622772865e44d200d248ed2676",
 "sha256:997ad98329327bc8cc90838a8804a5ad4c93d5286e03decf2715bbb035e4a5a1"
        ... ... ... ...省略
        
# tomcat (共10层)

... ... ... ...省略
 "RootFS":
 "sha256:c2ddc1bc2645ab5d982c60434d8bbc6aecee1bd4e8eee0df7fd08c96df2d58bb",
 "sha256:62d14713f2e98841ec3927e3ab611b13e414a21fb82fc0e604a9008ac53e45dc",
 "sha256:1235daf38153d083ae5b4f605acc54f9401143b5fbd033801ba373a8cfb04845",
 "sha256:7d890913ab6955350bdd25d04c60dd444db13890c401cbcdc8e00e9bd29c90fc",
 "sha256:c2e2307780ac2fa0d39cec874c4545156da890c1bcc42b3259114ac29bb598f1",
 "sha256:75f6a0e6e441cd3d74125443fc73eb26bf9ceb557b269b25bddaa2ef459227f7",
 "sha256:b19f17003e5ae07f7aba99f95736627aaa1ff3c92832f7d6920158dc6b138bcf",
 "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 --help

Commands:
  create      Create a volume
  inspect     Display detailed information on one or more volumes
  ls          List volumes
  prune       Remove all unused local volumes
  rm          Remove one or more volumes

➜  / docker volume ls  
DRIVER    VOLUME NAME
local     4b13ad4d9594573dc7d7b2cc944ae56b838c3b437aa3735377fb0f25c25cb526
local     d205865d4dcd5d50c97c09f532d580350f65180f2d1b3f48b425a71ea9ed0135
local     juming-nginx
# 前两个分别是mysql 和 nginx 的匿名挂载, 第三个是 nginx 的具名挂载
➜  / docker volume inspect juming-nginx
[
    {
        "CreatedAt": "2021-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": "2021-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 nginx
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx

# 一旦设置了容器权限, 容器对挂载出来的内容就有了限定
# 设定为 ro 时, 这个路径将只能通过宿主机来操作, 容器内部是无法操作的

初始Dockerfile

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

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

创建路径		 mkdir /home/docker-test-volume 
创建编辑文件		vim dockerfile1
# 自定义Dockerfile
FORM 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.048kB
Step 1/4 : FROM centos
 ---> 300e315adb2f
Step 2/4 : VOLUME ["volume01", "volume02"]
 ---> Running in add71936df4a
Removing intermediate container add71936df4a
 ---> f005f45db9de
Step 3/4 : CMD echo "----end----"
 ---> Running in 01b8f543c1bc
Removing intermediate container 01b8f543c1bc
 ---> 0ef638078484
Step 4/4 : CMD /bin/bash
 ---> Running in 89be86ba72c5
Removing intermediate container 89be86ba72c5
 ---> 37a96d02edb1
Successfully built 37a96d02edb1
Successfully tagged mushan/centos:1.0

# 成功生成镜像
➜  docker-test-volume docker images
REPOSITORY            TAG       IMAGE ID       CREATED         SIZE
mushan/centos         1.0       37a96d02edb1   6 minutes ago   209MB

数据卷容器

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

测试:

创建三个centos镜像

docker run -it --name="centos01" mushan/centos:1.0 /bin/bash
docker run -it --name="centos02" --volumes-from centos01 centos:latest /bin/bash
docker 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 ls
mushan

# 把路径删除/4883e91e3f0583ba8e03081644542386ef685b28bd34bcb9c1e86fb3566dec7c
rm -rf 4883e91e3f0583ba8e03081644542386ef685b28bd34bcb9c1e86fb3566dec7c

# 此时无论在哪个容器中创建文件/文件夹都会失败
[root@6dd479046fcf volume01]# mkdir mushan
mkdir: cannot create directory 'mushan': No such file or directory

# 此时就算把文件夹创建回来也没有用

DockerFile

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

构建步骤

  1. 编写一个dockerfile文件
  2. docker build 构建成为一个镜像
  3. docker run 运行镜像
  4. docker push 发布镜像( Docker Hub , 阿里云镜像仓库)
# centos-8官方dockerfile
FROM scratch
ADD 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="20201204"
CMD ["/bin/bash"]

DockerFile 的创建

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

CMD: 命令可以用于默认设置, 比如启动方式/bin/bash为默认, 但是如果用户想通过其他的方式启动, 默认失效

发布镜像

DockerHub

  1. 登录DockerHub

    docker login 用户名
    password: 输入密码
    
  2. tag命令修改镜像名(添加一个标签)

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

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

Docker网络

docker0

ip addr		# 查看ip

在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MuShan-bit

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值