本篇将进一步介绍Docker,主要介绍Docker常用命令,Docker容器数据卷,Docker镜像等内容。
Docker常用命令
1.帮助命令
docker version
docker info
docker --help
2.镜像命令
- 列出本地主机上的镜像
docker images [OPTIONS]
OPTIONS参数说明:
-a :列出本地所有的镜像(含中间映像层)
-q :只显示镜像ID。
--digests :显示镜像的摘要信息
--no-trunc :显示完整的镜像信息
运行效果:
[图片上传失败...(image-951668-1634286574472)]
说明:
REPOSITORY:表示镜像的仓库源
TAG:镜像的标签,相当于版本号
IMAGE ID:镜像ID
CREATED:镜像创建时间
SIZE:镜像大小
- 搜索镜像
docker search [OPTIONS] 镜像名字
OPTIONS参数说明:
--no-trunc : 显示完整的镜像描述
-s : 列出收藏数不小于指定值的镜像。
--automated : 只列出 automated build类型的镜像;
- 拉取下载镜像
docker pull 镜像名字[:TAG]
:TAG : 标签,相当于版本号
- 删除镜像
docker rmi 镜像名字/镜像ID
docker rmi -f 镜像ID #删除单个
docker rmi -f 镜像名1:TAG 镜像名2:TAG #删除多个
docker rmi -f $(docker images -qa) #删除全部,$(docker images -qa)表示查询出所有的镜像ID
-
commit镜像
可以通过docker commit 容器副本使之成为新的镜像
docker commit -m “提交的描述信息” -a “作者” 容器ID 要创建的目标镜像名:[标签名]
3.容器命令
- 新建并启动容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
OPTIONS说明(常用):
--name="容器新名字": 为容器指定一个名称;
-d: 后台运行容器,并返回容器ID,也即启动守护式容器;
-i:以交互模式运行容器,通常与 -t 同时使用;
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-P: 随机端口映射;
-p: 指定端口映射,有四种
hostPort:containerPort
ip:hostPort:containerPort
ip::containerPort
containerPort
COMMAND说明:启动容器后,并在容器执行某个指令
ARG说明:传递的参数
示例:启动交互式容器,指定端口映射,并在容器内执行/bin/bash命令
docker run -it -p 8080:8080 jenkins123 /bin/bash
[图片上传失败...(image-180547-1634286574472)]
示例:启动守护式容器
docker run -d -p 8080:8080 jenkins123
[图片上传失败...(image-63cabf-1634286574472)]
需要注意:
Docker容器后台运行,就必须有一个前台进程。
容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。
- 列出当前所有正在运行的容器
docker ps [OPTIONS]
OPTIONS说明(常用):
-a :列出当前所有正在运行的容器+历史上运行过的
-l :显示最近创建的容器。
-n:显示最近n个创建的容器。
-q :静默模式,只显示容器编号。
--no-trunc :不截断输出。
组合使用 docker ps -qa 查询所有容器id
- 退出容器
exit #容器停止退出
ctrl+P+Q #容器不停止退出
- 启动容器
docker start 容器ID或者容器名
- 停止容器
docker stop 容器ID或者容器名
- 强制停止容器
docker kill 容器ID或者容器名
- 重启容器
docker restart 容器ID或者容器名
- 删除已停止的容器
docker rm 容器ID
docker rm -f $(docker ps -qa) #删除多个
- 查看容器日志
docker logs -f -t --tail 容器ID
参数说明:
-t 是加入时间戳
-f 跟随最新的日志打印
--tail 数字 显示最后多少条
- 查看容器内运行的进程
docker top 容器ID
- 查看容器内部细节
docker inspect 容器ID
- 进入正在运行的容器
#方式一
docker exec -it 容器ID /bin/bash #在容器中打开新的终端,会启动新的进程
#方式二
docker attach 容器ID #直接进入容器启动命令的终端,不会启动新的进程
- 从容器内拷贝文件到主机上
docker cp 容器ID:容器内路径 目的主机路径
4.总结一下
attach # 当前 shell 下 attach 连接指定运行镜像
build # 通过 Dockerfile 定制镜像
commit # 提交当前容器为新的镜像
cp # 从容器中拷贝指定文件或者目录到宿主机中
create # 创建一个新的容器,同 run,但不启动容器
diff # 查看 docker 容器变化
events # 从 docker 服务获取容器实时事件
exec # 在已存在的容器上运行命令
export # 导出容器的内容流作为一个 tar 归档文件[对应 import ]
history # 展示一个镜像形成历史
images # 列出系统当前镜像
import # 从tar包中的内容创建一个新的文件系统映像[对应export]
info # 显示系统相关信息
inspect # 查看容器详细信息
kill # kill 指定 docker 容器
load # 从一个 tar 包中加载一个镜像[对应 save]
login # 注册或者登陆一个 docker 源服务器
logout # 从当前 Docker registry 退出
logs # 输出当前容器日志信息
port # 查看映射端口对应的容器内部源端口
pause # 暂停容器
ps # 列出容器列表
pull # 从docker镜像源服务器拉取指定镜像或者库镜像
push # 推送指定镜像或者库镜像至docker源服务器
restart # 重启运行的容器
rm # 移除一个或者多个容器
rmi # 移除一个或多个镜像[无容器使用该镜像才可删除,否则需删除相关容器才可继续或 -f 强制删除]
run # 创建一个新的容器并运行一个命令
save # 保存一个镜像为一个 tar 包[对应 load]
search # 在 docker hub 中搜索镜像
start # 启动容器
stop # 停止容器
tag # 给源中镜像打标签
top # 查看容器中运行的进程信息
unpause # 取消暂停容器
version # 查看 docker 版本号
wait # 截取容器停止时的退出状态值
Docker容器数据卷
作用
- 容器的持久化,类似我们Redis里面的rdb和aof文件
- 容器间继承+共享数据
给容器添加数据卷
- 命令添加
docker run -d -v /宿主机绝对路径目录:/容器内目录 镜像名/ID
#注意:如果出现cannot open directory,需要多加一个参数 --privileged=true
#查看是否挂载成功
docker inspect 容器ID
如果成功会显示:
[图片上传失败...(image-b23a5d-1634286574472)]
数据同步效果
在主机中写入一个hello文件
[图片上传失败...(image-658629-1634286574472)]
在容器中能同步到主机写入的hello文件
[图片上传失败...(image-b4a86e-1634286574472)]
- 通过DockerFile添加,等后面介绍DockerFIle时,一同介绍。
Docker镜像
为了更好了解docker镜像是什么,我们先来了解一下UnionFS(联合文件系统)。
UnionFS
Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下。
Docker镜像组成
docker的镜像实际上由一层一层的文件系统组成,Union 文件系统是 Docker 镜像的基础,镜像可以通过分层来进行继承,基于基础镜像,可以制作各种具体的应用镜像。
所以,当去拉取一个镜像时,在下载的过程中可以看到dockers是一层一层下载的。
[图片上传失败...(image-2c2975-1634286574472)]
采用这种分层结构的好处:共享资源,节约空间。
举个例子:假如有多个镜像都从相同的 base 镜像构建而来,那么宿主机只需在磁盘上保存一份base镜像,同时内存中也只需加载一份 base 镜像,就可以为所有容器服务了。而且镜像的每一层都可以被共享
通过容器副本构建一个新的镜像
Docker镜像有个特点,都是只读的。
所以,可以通过docker commit 容器副本使之成为新的镜像。
docker commit -m=“提交的描述信息” -a=“作者” 容器ID 要创建的目标镜像名:[标签名]
操作过程
- 通过docker pull 拉取一个镜像,并运行起来。
- 期间可以进入容器,进行相应定制修改操作。
- 通过docker commit该容器副本使之成为新的镜像。