1. 帮助命令

  1. docker version # 查看docker版本
  2. docker info # 查看docker信息
  3. docker --help # 查看帮助信息,列出所有命令

2. 镜像命令

2.1 docker images

列出本地主机上的镜像

同一仓库源可以有多个 TAG,代表这个仓库源的不同个版本,使用 REPOSITORY:TAG 来定义不同的镜像。 如果不指定一个镜像的版本标签,例如只使用 ubuntu,docker 将默认使用 ubuntu:latest 镜像(最新版本) image.png 字段说明:

REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
表示镜像的仓库源 镜像的标签 镜像ID 镜像创建时间 镜像大小

常用选项:

  1. docker images [OPTIONS]
  2. # OPTIONS说明:
  3. # -a :列出本地所有的镜像(含中间映像层,可以理解为依赖的其他包)
  4. # -q :只显示镜像ID。
  5. # --digests :显示镜像的摘要信息
  6. # --no-trunc :显示完整的镜像信息

2.2 docker search

https://hub.docker.com查找(配的阿里云仅仅是用于下载,查找还是从dockerhub查找) image.png 常用选项:

  1. docker search [OPTIONS] 镜像名字
  2. # OPTIONS说明:
  3. # --no-trunc : 显示完整的镜像描述
  4. # -s : 列出star数不小于指定值的镜像。
  5. # --automated : 只列出 automated build自动构建类型的镜像;

2.3 docker pull

下载镜像 注意:不写**:TAG**版本号默认拉最新版 image.png

  1. docker pull 镜像名字[:TAG]
  2. docker pull tomcat # 等同于docker pull tomcat:latest

2.4 docker rmi

删除镜像

  1. # 删除单个
  2. docker rmi -f 镜像ID或者镜像名
  3. # 删除多个
  4. docker rmi -f 镜像名1:TAG 镜像名2:TAG
  5. # 删除全部,$()可以理解为el表达式传参
  6. docker rmi -f $(docker images -qa)

2.5 docker build

根据DockerFile,构建镜像

  1. docker build -f docker file路径 -t 命名空间/镜像名 .
  2. # 参数解释
  3. -f 指明dockerfile路径,如果不使用 -f,默认读取当前路径下的Dockerfile文件
  4. -t 指明镜像的命名空间和名称
  5. . 代表在当前目录,可以自定义,也可以指定远程URL

image.png

2.6 docker commit

提交容器副本使之成为一个新的镜像,可以理解成JAVA中的反射,用对象反射成类

  1. docker commit -m="提交的描述信息" -a="作者" 原容器ID 要创建的目标镜像名:[标签名]
  • 案例演示
  • 从Hub上下载tomcat镜像到本地并成功运行
    • 前台运行

image.png

  • 后台运行

image.png

  1. docker pull tomcat
  2. docker run -it -p 8080:8080 tomcat
  3. ## 参数说明(参考3.1 docker run)
  4. # -p 主机端口:docker容器端口,可以理解成端口映射(打隧道)
  5. # -P 随机分配端口
  6. # -i 交互
  7. # -t 终端
  • 故意删除上一步镜像生产tomcat容器的文档
  • 也即当前的tomcat运行实例是一个没有文档内容的容器,以它为模板commit一个没有doc的tomcat新镜像jshawn/tomcat ```bash docker commit -a=”jshawn” -m=”mytomcat” 原容器ID 名称空间/名称:tags

参数解释:

-a 作者 -m 描述 容器ID 以哪个容器为模板生成镜像 名称空间 自定义,可以理解为包名 名称 自定义,软件名 tags 自定义,版本号

  1. ![image.png](https://cdn.nlark.com/yuque/0/2021/png/668367/1639491566672-c5e162dc-13f4-4236-8508-125f2ebdcd36.png#clientId=ubd3c7dde-92dc-4&crop=0&crop=0&crop=1&crop=1&from=paste&id=u3dc36d99&margin=%5Bobject%20Object%5D&name=image.png&originHeight=251&originWidth=1310&originalType=binary&ratio=1&rotation=0&showTitle=false&size=47755&status=done&style=none&taskId=u3c748e06-5079-4df2-9d54-4e24c4f8326&title=)
  2. - 测试,启动新镜像并和原来的对比
  3. - 启动jshawn/tomcat,它没有docs
  4. - 重新启动原来的tomcat,它有docs
  5. <a name="CvAVo"></a>
  6. ## 2.7 docker push
  7. > **推送到远程仓库**
  8. > **参考:**[九、本地镜像发布到阿里云](https://www.yuque.com/shawn-ssup1/yn8b6h/ypa3ha)
  9. <a name="se6V8"></a>
  10. ## 2.8 docker history
  11. > **列出镜像的变更历史**
  12. ![image.png](https://cdn.nlark.com/yuque/0/2021/png/668367/1639650770405-cc715221-a9af-4fdb-8fa6-3aa738b29ccf.png#clientId=u8e97efdb-5d3d-4&crop=0&crop=0&crop=1&crop=1&from=paste&id=ua6886827&margin=%5Bobject%20Object%5D&name=image.png&originHeight=340&originWidth=1531&originalType=binary&ratio=1&rotation=0&showTitle=false&size=89053&status=done&style=none&taskId=uf0adc37a-cdca-4b02-8bb5-2e8ebd58cbe&title=)
  13. <a name="VdwMa"></a>
  14. # 3. 容器命令
  15. <a name="xoNzc"></a>
  16. ## 3.1 docker run------新建并启动容器
  17. > run干了什么:
  18. > 本地有镜像,以镜像创建一个容器实例运行
  19. > 本地没有镜像,先去仓库pull,然后是用pull好的镜像创建一个容器实例运行
  20. > ![image.png](https://cdn.nlark.com/yuque/0/2021/png/668367/1639461303517-bbfe7e2e-124a-460a-bce3-eeeb49fc9b56.png#clientId=u121669f5-6793-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=318&id=wCEbp&margin=%5Bobject%20Object%5D&name=image.png&originHeight=636&originWidth=1309&originalType=binary&ratio=1&rotation=0&showTitle=false&size=102840&status=done&style=none&taskId=ubcd53e44-ccf4-464d-a371-8ea53797436&title=&width=654.5)
  21. > ![image.png](https://cdn.nlark.com/yuque/0/2021/png/668367/1639479127355-2738341f-9574-4e30-8297-a26e3815f72c.png#clientId=uda398c72-9f8c-4&crop=0&crop=0&crop=1&crop=1&from=paste&id=u59a16676&margin=%5Bobject%20Object%5D&name=image.png&originHeight=77&originWidth=867&originalType=binary&ratio=1&rotation=0&showTitle=false&size=9837&status=done&style=none&taskId=uaca0ea13-003e-4a61-a09b-e5a4b09d6e2&title=)
  22. ```bash
  23. docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
  24. # OPTIONS说明(常用):有些是一个减号,有些是两个减号:
  25. --name="容器新名字": 为容器指定一个名称;
  26. --volumes-from:数据容器卷,继承于哪个容器
  27. -d: (重要)后台运行容器,并返回容器ID,也即启动守护式容器;
  28. -i:(重要)以交互模式运行容器,通常与 -t 同时使用;
  29. -t:(重要)为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  30. -v:(重要)/宿主机绝对路径目录:/容器内目录 镜像名,参考六、Docker容器数据卷 3.1 命令添加
  31. -P: 随机端口映射;
  32. -p: 指定端口映射,有以下四种格式
  33. ip:hostPort:containerPort
  34. ip::containerPort
  35. (重要)hostPort:containerPort
  36. containerPort
  37. # -i 参数 启动交互式容器
  38. # 使用镜像centos:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。
  39. docker run -it centos /bin/bash
  40. # -d 参数 启动守护式容器
  41. #使用镜像centos:latest以后台模式启动一个容器
  42. docker run -d centos
  43. # 问题:然后docker ps -a 进行查看, 会发现容器已经退出
  44. # 很重要的要说明的一点: Docker容器后台运行,就必须有一个前台进程.
  45. # 容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。
  46. # 这个是docker的机制问题,比如你的web容器,我们以nginx为例,正常情况下,我们配置启动服务只需要启动响应的service即可。
  47. # 例如 service nginx start
  48. # 但是,这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后,会立即自杀因为他觉得他没事
  49. # 可做了。所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行

image.png

3.2 docker ps———列出当前所有正在运行的容器

image.png 字段说明:

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
容器ID 镜像ID 命令 创建时间 状态
up:正在运行
Exited:停止并退出
端口 容器别名
  1. docker ps [OPTIONS]
  2. # OPTIONS说明(常用):
  3. -a :列出当前所有正在运行的容器+历史上运行过的
  4. -l :显示最近1次创建的容器。
  5. -n :显示最近n个创建的容器。
  6. -q :静默模式,只显示容器编号。
  7. --no-trunc :不截断输出。

3.3 exit/ctrl+P+Q———退出容器

  1. exit # 容器停止退出
  2. ctrl+P+Q # 容器不停止退出

3.4 docker start———启动容器

  1. docker start 容器ID或者容器名

3.5 docker restart———重启容器

  1. docker restart 容器ID或者容器名

3.6 docker stop———停止容器

  1. docker stop 容器ID或者容器名

3.7 docker kill———强制停止容器

  1. docker kill 容器ID或者容器名

3.8 docker rm———删除已停止的容器

  1. # 删除一个容器
  2. docker rm 容器ID
  3. # 一次性删除多个容器
  4. docker rm -f $(docker ps -a -q)
  5. docker ps -a -q | xargs docker rm

3.9 docker logs———查看容器日志

  1. docker logs -f -t --tail 容器ID
  2. -t 是加入时间戳
  3. -f 跟随最新的日志打印
  4. --tail 数字 显示最后多少条

3.10 docker top———查看容器内运行的进程

  1. docker top 容器ID

3.11 docker inspect———查看容器内部细节

  1. docker inspect 容器ID

3.12 docker exec/attach———进入正在运行的容器并以命令行交互

image.png image.png image.png

  1. # (推荐)进入正在运行的容器并以命令行交互
  2. docker exec -it 容器ID /bin/bash
  3. # 在容器外执行命令,不进入容器
  4. docker exec -it 容器ID COMMAND [ARGS]
  5. # 重新进入正在运行的容器并以命令行交互
  6. docker attach 容器ID
  7. # 两者的区别:
  8. attach 直接进入容器启动命令的终端,不会启动新的进程
  9. exec 是在容器中打开新的终端,并且可以启动新的进程,(重要)并且可以在容器外执行命令(类似hadoop命令)

3.13 docker cp———从容器内拷贝文件到主机上

  1. docker cp 容器ID:容器内路径 目的主机路径

4. 常用命令总结

  1. attach Attach to a running container # 当前 shell 下 attach 连接指定运行镜像
  2. build Build an image from a Dockerfile # 通过 Dockerfile 定制镜像
  3. commit Create a new image from a container changes # 提交当前容器为新的镜像
  4. cp Copy files/folders from the containers filesystem to the host path #从容器中拷贝指定文件或者目录到宿主机中
  5. create Create a new container # 创建一个新的容器,同 run,但不启动容器
  6. diff Inspect changes on a container's filesystem # 查看 docker 容器变化
  7. events Get real time events from the server # 从 docker 服务获取容器实时事件
  8. exec Run a command in an existing container # 在已存在的容器上运行命令
  9. export Stream the contents of a container as a tar archive # 导出容器的内容流作为一个 tar 归档文件[对应 import ]
  10. history Show the history of an image # 展示一个镜像形成历史
  11. images List images # 列出系统当前镜像
  12. import Create a new filesystem image from the contents of a tarball # 从tar包中的内容创建一个新的文件系统映像[对应export]
  13. info Display system-wide information # 显示系统相关信息
  14. inspect Return low-level information on a container # 查看容器详细信息
  15. kill Kill a running container # kill 指定 docker 容器
  16. load Load an image from a tar archive # 从一个 tar 包中加载一个镜像[对应 save]
  17. login Register or Login to the docker registry server # 注册或者登陆一个 docker 源服务器
  18. logout Log out from a Docker registry server # 从当前 Docker registry 退出
  19. logs Fetch the logs of a container # 输出当前容器日志信息
  20. port Lookup the public-facing port which is NAT-ed to PRIVATE_PORT # 查看映射端口对应的容器内部源端口
  21. pause Pause all processes within a container # 暂停容器
  22. ps List containers # 列出容器列表
  23. pull Pull an image or a repository from the docker registry server # 从docker镜像源服务器拉取指定镜像或者库镜像
  24. push Push an image or a repository to the docker registry server # 推送指定镜像或者库镜像至docker源服务器
  25. restart Restart a running container # 重启运行的容器
  26. rm Remove one or more containers # 移除一个或者多个容器
  27. rmi Remove one or more images # 移除一个或多个镜像[无容器使用该镜像才可删除,否则需删除相关容器才可继续或 -f 强制删除]
  28. run Run a command in a new container # 创建一个新的容器并运行一个命令
  29. save Save an image to a tar archive # 保存一个镜像为一个 tar 包[对应 load]
  30. search Search for an image on the Docker Hub # 在 docker hub 中搜索镜像
  31. start Start a stopped containers # 启动容器
  32. stop Stop a running containers # 停止容器
  33. tag Tag an image into a repository # 给源中镜像打标签
  34. top Lookup the running processes of a container # 查看容器中运行的进程信息
  35. unpause Unpause a paused container # 取消暂停容器
  36. version Show the docker version information # 查看 docker 版本号
  37. wait Block until a container stops, then print its exit code # 截取容器停止时的退出状态值