本篇将进一步介绍Docker,主要介绍Docker常用命令,Docker容器数据卷,Docker镜像等内容。
Docker常用命令 1.帮助命令docker version docker info docker --help2.镜像命令
- 列出本地主机上的镜像
docker images [OPTIONS] OPTIONS参数说明: -a :列出本地所有的镜像(含中间映像层) -q :只显示镜像ID。 --digests :显示镜像的摘要信息 --no-trunc :显示完整的镜像信息
运行效果:
说明:
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
示例:启动守护式容器
docker run -d -p 8080:8080 jenkins123
需要注意:
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
如果成功会显示:
数据同步效果
在主机中写入一个hello文件
在容器中能同步到主机写入的hello文件
- 通过DockerFile添加,等后面介绍DockerFIle时,一同介绍。
为了更好了解docker镜像是什么,我们先来了解一下UnionFS(联合文件系统)。
UnionFSUnion文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下。
Docker镜像组成docker的镜像实际上由一层一层的文件系统组成,Union 文件系统是 Docker 镜像的基础,镜像可以通过分层来进行继承,基于基础镜像,可以制作各种具体的应用镜像。
所以,当去拉取一个镜像时,在下载的过程中可以看到dockers是一层一层下载的。
采用这种分层结构的好处:共享资源,节约空间。
举个例子:假如有多个镜像都从相同的 base 镜像构建而来,那么宿主机只需在磁盘上保存一份base镜像,同时内存中也只需加载一份 base 镜像,就可以为所有容器服务了。而且镜像的每一层都可以被共享
Docker镜像有个特点,都是只读的。
所以,可以通过docker commit 容器副本使之成为新的镜像。
docker commit -m=“提交的描述信息” -a=“作者” 容器ID 要创建的目标镜像名:[标签名]操作过程
- 通过docker pull 拉取一个镜像,并运行起来。
- 期间可以进入容器,进行相应定制修改操作。
- 通过docker commit该容器副本使之成为新的镜像。



