1、Docker信息

  1. ##查看docker容器版本
  2. docker version
  3. ##查看docker容器信息
  4. docker info
  5. ##查看docker容器帮助
  6. docker --help

2、镜像操作

2.1、镜像查看

  1. ##列出本地images
  2. docker images
  3. ##含中间映像层
  4. docker images -a
  5. ##只显示镜像ID
  6. docker images -q
  7. ##含中间映像层
  8. docker images -qa
  9. ##显示镜像摘要信息(DIGEST列)
  10. docker images --digests
  11. ##显示镜像完整信息
  12. docker images --no-trunc
  13. ##显示指定镜像的历史创建;参数:-H 镜像大小和日期,默认为true;--no-trunc 显示完整的提交记录;-q 仅列出提交记录ID
  14. docker history -H redis

2.2、镜像搜索

  1. ##搜索仓库MySQL镜像
  2. docker search mysql
  3. ## --filter=stars=600:只显示 starts>=600 的镜像
  4. docker search --filter=stars=600 mysql
  5. ## --no-trunc 显示镜像完整 DESCRIPTION 描述
  6. docker search --no-trunc mysql
  7. ## --automated :只列出 AUTOMATED=OK 的镜像
  8. docker search --automated mysql

2.3、镜像下载

  1. ##下载Redis官方最新镜像,相当于:docker pull redis:latest
  2. docker pull redis
  3. ##下载仓库所有Redis镜像
  4. docker pull -a redis
  5. ##下载私人仓库镜像
  6. docker pull bitnami/redis

2.4、镜像删除

  1. ##单个镜像删除,相当于:docker rmi redis:latest
  2. docker rmi redis
  3. ##强制删除(针对基于镜像有运行的容器进程)
  4. docker rmi -f redis
  5. ##多个镜像删除,不同镜像间以空格间隔
  6. docker rmi -f redis tomcat nginx
  7. ##删除本地全部镜像
  8. docker rmi -f $(docker images -q)

2.5、镜像构建

Dockerfile
构建前端项目

  1. FROM nginx:latest
  2. COPY ./dist /usr/share/nginx/html/
  3. COPY ./default.conf /etc/nginx/conf.d/
  4. EXPOSE 80
  5. #其中 -t 对镜像进行命名,一般的命名法:仓库名字/镜像名字:版本号
  6. #注意:其中 .号,代表当前目录下的dockerfile文件
  7. docker build -t registry-name/name-server:1.0.0 .
  8. # 将主机的8080端口映射到容器里的80端口
  9. docker run -d -p 8080:80 --name=container_name registry-name/name-server:1.0.0

构建spring项目

  1. FROM openjdk:8-jdk-alpine
  2. ADD *.jar app.jar
  3. ENTRYPOINT ["java","-jar","/app.jar"]
  4. EXPOSE 8088
  5. #其中 -t 对镜像进行命名,一般的命名法:仓库名字/镜像名字:版本号
  6. #注意:其中 .号,代表当前目录下的dockerfile文件
  7. docker build -t registry-name/name-server:1.0.0 .
  8. # 将主机的8080端口映射到容器里的80端口
  9. docker run -d -p 8080:8088 --name=container_name registry-name/name-server:1.0.0

3、容器操作

提示:对于容器的操作可使用CONTAINER ID 或 NAMES。

3.1、容器启动

  1. ##新建并启动容器,参数:-i 以交互模式运行容器;-t 为容器重新分配一个伪输入终端;--name 为容器指定一个名称
  2. docker run -i -t --name mycentos
  3. ##后台启动容器,参数:-d 已守护方式启动容器
  4. docker run -d mycentos
  5. ##在 docker 中设置容器自动启动
  6. #使用 docker run 命令运行时
  7. 增加 --restart=always 参数即可
  8. #使用 docker-compose 命令运行时
  9. yml 文件中,需要自启动的 service
  10. 增加 restart: always 项目即可
  11. #已运行的容器修改其自启动策略
  12. 执行命令:
  13. docker update --restart=always 容器名或容器ID

注意:此时使用”docker ps -a”会发现容器已经退出。这是docker的机制:要使Docker容器后台运行,就必须有一个前台进程。解决方案:将你要运行的程序以前台进程的形式运行。

  1. ##启动一个或多个已经被停止的容器
  2. docker start redis
  3. ##重启容器
  4. docker restart redis

3.2、容器进程

  1. ##top支持 ps 命令参数,格式:docker top [OPTIONS] CONTAINER [ps OPTIONS]
  2. ##列出redis容器中运行进程
  3. docker top redis
  4. ##查看所有运行容器的进程信息
  5. for i in `docker ps |grep Up|awk '{print $1}'`;do echo \ &&docker top $i; done

3.3、容器日志

  1. ##查看redis容器日志,默认参数
  2. docker logs rabbitmq
  3. ##查看redis容器日志,参数:-f 跟踪日志输出;-t 显示时间戳;--tail 仅列出最新N条容器日志;
  4. docker logs -f -t --tail=20 redis
  5. ##查看容器redis20190521日后的最新10条日志。
  6. docker logs --since="2019-05-21" --tail=10 redis

3.4、容器的进入与退出

  1. ##使用run方式在创建时进入
  2. docker run -it centos /bin/bash
  3. ##关闭容器并退出
  4. exit
  5. ##仅退出容器,不关闭
  6. 快捷键:Ctrl + P + Q
  7. ##直接进入centos 容器启动命令的终端,不会启动新进程,多个attach连接共享容器屏幕,参数:--sig-proxy=false 确保CTRL-DCTRL-C不会关闭容器
  8. docker attach --sig-proxy=false centos
  9. ##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i 即使没有附加也保持STDIN 打开;-t 分配一个伪终端
  10. docker exec -i -t centos /bin/bash
  11. ##以交互模式在容器中执行命令,结果返回到当前终端屏幕
  12. docker exec -i -t centos ls -l /tmp
  13. ##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端
  14. docker exec -d centos touch cache.txt

3.5、查看容器

  1. ##查看正在运行的容器
  2. docker ps
  3. ##查看正在运行的容器的ID
  4. docker ps -q
  5. ##查看正在运行+历史运行过的容器
  6. docker ps -a
  7. ##显示运行容器总文件大小
  8. docker ps -s
  9. ##显示最近创建容器
  10. docker ps -l
  11. ##显示最近创建的3个容器
  12. docker ps -n 3
  13. ##不截断输出
  14. docker ps --no-trun
  15. ##获取镜像redis的元信息
  16. docker inspect redis
  17. ##获取正在运行的容器redis IP
  18. docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis

3.6、容器的停止与删除

  1. ##停止一个运行中的容器
  2. docker stop redis
  3. ##杀掉一个运行中的容器
  4. docker kill redis
  5. ##删除一个已停止的容器
  6. docker rm redis
  7. ##删除一个运行中的容器
  8. docker rm -f redis
  9. ##删除多个容器
  10. docker rm -f $(docker ps -a -q)
  11. docker ps -a -q | xargs docker rm
  12. ## -l 移除容器间的网络连接,连接名为 db
  13. docker rm -l db
  14. ## -v 删除容器,并删除容器挂载的数据卷
  15. docker rm -v redis

3.7、生成镜像

  1. ##基于当前redis容器创建一个新的镜像;参数:-a 提交的镜像作者;-c 使用Dockerfile指令来创建镜像;-m :提交时的说明文字;-p :在commit时,将容器暂停
  2. docker commit -a="DeepInThought" -m="my redis" [redis容器ID] myredis:v1.1

3.8、容器与主机间的数据拷贝

  1. ##将rabbitmq容器中的文件copy至本地路径
  2. docker cp rabbitmq:/[container_path] [local_path]
  3. ##将主机文件copyrabbitmq容器
  4. docker cp [local_path] rabbitmq:/[container_path]/
  5. ##将主机文件copyrabbitmq容器,目录重命名为[container_path](注意与非重命名copy的区别)
  6. docker cp [local_path] rabbitmq:/[container_path]