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不能被代理