3.Docker命令与语法

docker学习教程,参考 https://www.runoob.com/docker

查看docker版本

docker version

Docker镜像命令

命令 用途 示例
docker pull name:tag 下载镜像 docker pull nginx:1.17.0
docker images 列出所有镜像 docker images
docker search 搜索hub库中的镜像文件,网址:https://hub.docker.com docker search ngxin
docker rmi 删除imagse docker rmi nginx:1.17.0
docker rmi -f 指定名称删除镜像(强制) docker rmi -f nginx:1.17.0
docker rmi -f $(docker images) 强制删除所有镜像 docker rmi -f $(docker images)

Docker镜像生成导入导出

命令 用途 示例
docker bulid 构建Dockerfile “.”当前目录,t标签 docker build . -t mynginx:1.0.0
docker save 将镜像完全导出 docker save -o mynginx.tar mynginx:1.0.0
docker load 将tar导入镜像列表 docker load --input mynginx.tar 或 docker load < mynginx.tar
docker export 将容器读写层文件系统导出一个tar包 docker export -o mynginx.tar a47f4eebc884
docker import 将tar包容器导入一个镜像(修改的东西还在) dkn/mynginx:1.0.1必须自定义一个,运行时需要加入命令 docker import mynginx.tar dkn/mynginx:1.0.1
docker cp 在host和container之间拷贝文件 docker cp /root/index.html a47f4eebc884:/usr/share/nginx/html 或 docker cp a47f4eebc884:/usr/share/nginx/html/index.html /root 或目录 docker cp a47f4eebc884:/usr/share/nginx/html /root
docker commit 保存容器改动,生成的新的镜像, https://www.runoob.com/docker/docker-commit-command.html docker commit -a "dkn" -m "update info" a404c6c174a2 mynginx:1.0.2
  • docker save images_name:将一个【镜像】导出为文件,再使用docker load命令将文件导入为一个镜像,会保存该镜像的的所有历史记录。比docker export命令导出的文件大,很好理解,因为会保存镜像的所有历史记录。

  • docker export container_id:将一个【容器】导出为文件,再使用docker import 命令将容器导入成为一个新的镜像,但是相比docker save命令,容器文件会丢失所有元数据和历史记录,仅保存容器当时的状态,相当于虚拟机快照。

  • docker export import,导入镜像后,启动时报错误“Error response from daemon: No command specified” 的处理
    docker export --> import --> 启动 时可能会报错“Error response from daemon: No command specified”,需要带command,可以在原来的容器所在主机上执行docker ps查看到,如果command比较复杂,还是使用docker save --> load --> 启动 的方式好了,这种方式启动就不必带command。

  • Docker导入容器快照,执行报错:docker: Error response from daemon: No command specified.

    参考地址 :https://www.cnblogs.com/mySummer/p/12328073.html
    

Docker容器命令

命令 用途
docker pull 获取image
docker stop 停止容器 别名或id
docker kill 强制停止容器
docker rm 删除指定容器
docker rm -f 停止并删除容器 别名或id
docker rm -f $(docker ps -a -q) 强制删除所有容器
docker ps 查看正在运行
docker ps -a 查看所有容器
docker run 创建container并运行 -itd --add-host abc:192.168.1.123动态添加host主机 -e设置环境变量 -p暴露端口(宿主机:容器
docker exec 在正在运行的容器中运行命令 -d在后台运行 -e设置环境变量 -i互动 -t伪终端
docker exec -it 容器id或名称 /bin/bash 进入容器
docker inspect --format '{{ .NetworkSettings.IPAddress }}' 容器id或名称 查看容器ip
docker logs 容器id或名字 -f 查看容器的日志 -f 跟踪实时日志
docker stats 动态查看容器利用率 cpu 内存 io等
docker stop 停止容器
docker start 启动容器
docker restart 重启容器
docker create 创建容器不启动
docker diff 容器启动以来新增了什么文件
docker rename a b 修改容器名称 a为旧名字 b为新名字
docker inspect 容器信息
  -d, --detach=false         指定容器运行于前台还是后台,默认为false    
  -i, --interactive=false    打开STDIN,用于控制台交互   
  -t, --tty=false            分配tty设备,该可以支持终端登录,默认为false   
  -u, --user=""              指定容器的用户   
  -a, --attach=[]            登录容器(必须是以docker run -d启动的容器) 
  -w, --workdir=""           指定容器的工作目录  
  -c, --cpu-shares=0         设置容器CPU权重,在CPU共享场景使用   
  -e, --env=[]               指定环境变量,容器中可以使用该环境变量   
  -m, --memory=""            指定容器的内存上限   
  -P, --publish-all=false    指定容器暴露的端口   
  -p, --publish=[]           指定容器暴露的端口  
  -h, --hostname=""          指定容器的主机名   
  -v, --volume=[]            给容器挂载存储卷,挂载到容器的某个目录   
  --volumes-from=[]          给容器挂载其他容器上的卷,挂载到容器的某个目录 
  --cap-add=[]               添加权限,权限清单详见:http://linux.die.net/man/7/capabilities   
  --cap-drop=[]              删除权限,权限清单详见:http://linux.die.net/man/7/capabilities   
  --cidfile=""               运行容器后,在指定文件中写入容器PID值,一种典型的监控系统用法   
  --cpuset=""                设置容器可以使用哪些CPU,此参数可以用来容器独占CPU   
  --device=[]                添加主机设备给容器,相当于设备直通   
  --dns=[]                   指定容器的dns服务器   
  --dns-search=[]            指定容器的dns搜索域名,写入到容器的/etc/resolv.conf文件   
  --entrypoint=""            覆盖image的入口点   
  --env-file=[]              指定环境变量文件,文件格式为每行一个环境变量   
  --expose=[]                指定容器暴露的端口,即修改镜像的暴露端口   
  --link=[]                  指定容器间的关联,使用其他容器的IP、env等信息   
  --lxc-conf=[]              指定容器的配置文件,只有在指定--exec-driver=lxc时使用   
  --name=""                  指定容器名字,后续可以通过名字进行容器管理,links特性需要使用名字   
  --net="bridge"             容器网络设置: 
                                bridge 使用docker daemon指定的网桥      
                                host    //容器使用主机的网络   
                                container:NAME_or_ID  >//使用其他容器的网路,共享IP和PORT等网络资源   
                                none 容器使用自己的网络(类似--net=bridge),但是不进行配置  
  --privileged=false         指定容器是否为特权容器,特权容器拥有所有的capabilities   
  --restart="no"             指定容器停止后的重启策略: 
                                no:容器退出时不重启   
                                on-failure:容器故障退出(返回值非零)时重启  
                                always:容器退出时总是重启   
  --rm=false                 指定容器停止后自动删除容器(不支持以docker run -d启动的容器)   
  --sig-proxy=true           设置由代理接受并处理信号,但是SIGCHLD、SIGSTOP和SIGKILL不能被代理 
原文地址:https://www.cnblogs.com/daikainan/p/14280252.html