docker常用命令总结
docker常用命令总结
docker run
-d, --detach=false # 后台运行容器,并返回容器ID; -i, --interactive=false # 以交互模式运行容器,通常与 -t 同时使用; -t, --tty=false # 为容器重新分配一个伪输入终端,通常与 -i 同时使用; -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不能被代理
示例
使用docker镜像tomcat:latest以后台模式启动一个容器,并将容器命名为mytomcat docker run -tid --name mytomcat tomcat:latest 使用镜像tomcat:latest以后台模式启动一个容器,并将容器的8080端口映射到宿主机的8080端口 docker run -tid --name mytomcat -p 8080:8080 tomcat:latest 使用镜像tomcat:latest以后台模式启动一个容器,并将容器的8080端口映射到宿主机的8080端口,主机的目录 /home 映射到容器的 /home 容器暴露80端口,并指定宿主机80端口与其通信(之前是宿主机端口,之后是容器需暴露的端口) docker run -d --name=ubuntu_server -p 80:80 ubuntu:latest 指定容器内目录与宿主机目录共享(之前是宿主机文件夹,之后是容器需共享的文件夹), docker run -d --name=ubuntu_server -v /etc/www:/var/www ubuntu:latest 指定bridge网桥 docker run -it --net=my_bridge nginx
容器操作
docker create # 创建一个容器但是不启动它 docker run # 创建并启动一个容器 docker stop # 停止容器运行,发送信号 SIGTERM docker kill # 强制终止一个容器 docker start # 启动一个停止状态的容器 docker restart # 重启一个容器 docker rmi # 删除一个容器 docker rm $(docker ps -a -q) docker kill # 发送信号给容器,默认 SIGKILL docker attach # 连接 ( 进入 ) 到一个正在运行的容器 docker wait # 阻塞到一个容器,直到容器停止运行 docker --restart=always # 容器关闭之后自动启动
获取容器信息
docker ps # 显示状态为运行( Up )的容器 docker ps -a # 显示所有容器 , 包括运行中( Up )的和退出的 (Exited) docker inspect # 深入容器内部获取容器所有信息 docker logs -f # 查看容器的日志 (stdout/stderr) (-f 用于实时输出 ) docker events # 得到 docker 服务器的实时的事件 docker port # 显示容器的端口映射 docker top # 显示容器的进程信息 docker diff # 显示容器文件系统的前后变化
导出容器
docker cp # 从容器里向外拷贝文件或目录 docker export containe_id >export.tar # 将容器整个文件系统导出为一个 tar 包,不带 layers 、 tag 等信息 docker export container_id >export.tar # 导出容器保存到本地并命名为 export.tar cat export.tar | docker import - imported:container # 导入本地 tar 包作为一个镜像 docker import url res:tag # 导入网络的容器作为一个镜像
镜像操作
docker images # 显示本地所有的镜像列表 docker import # 从一个 tar 包创建一个镜像,往往和 export 结合使用 docker build # 使用 Dockerfile 创建镜像(推荐) docker commit # 从容器创建镜像 docker rmi # 删除一个镜像 docker load # 从一个 tar 包创建一个镜像,和 save 配合使用 docker save # 将一个镜像保存为一个 tar 包,带 layers 和 tag 信息 docker history # 显示生成一个镜像的历史命令 docker tag # 为镜像起一个别名
镜像仓库 (registry) 操作
docker login # 登录到一个 registry docker search # 从 registry 仓库搜索镜像 docker pull # 从仓库下载镜像到本地 docker push # 将一个镜像 push 到 registry 仓库中 # 获取 Container IP 地址( Container 状态必须是 Up ) docker inspect id | grep IPAddress | cut -d '"' -f 4 # 获取端口映射 docker inspect -f '{{range $p, $conf := .NetworkSettings.Ports}} {{$p}} -> {{(index $conf 0).HostPort}} {{end}}' id # 获取环境变量 docker exec container_id env # 杀掉所有正在运行的容器 docker kill $(docker ps -q) # 删除老的 ( 一周前创建 ) 容器 docker ps -a | grep 'weeks ago' | awk '{print $1}' | xargs docker rm # 删除已经停止的容器 docker rm `docker ps -a -q` # 删除所有镜像,小心 docker rmi $(docker images -q)
Dockerfile
FROM , 从一个基础镜像构建新的镜像 FROM ubuntu MAINTAINER , 维护者信息 MAINTAINER William <wlj@nicescale.com> ENV , 设置环境变量 ENV TEST 1 RUN , 非交互式运行 shell 命令 RUN apt-get -y update RUN apt-get -y install nginx ADD , 将外部文件拷贝到镜像里 ,src 可以为 url ADD http://nicescale.com/ /data/nicescale.tgz WORKDIR /path/to/workdir, 设置工作目录 WORKDIR /var/www USER , 设置用户 ID USER nginx VULUME <#dir>, 设置 volume VOLUME [‘/data’] EXPOSE , 暴露哪些端口 EXPOSE 80 443 ENTRYPOINT [‘executable’, ‘param1’,’param2’] 执行命令 ENTRYPOINT ["/usr/sbin/nginx"] CMD [“param1”,”param2”] CMD ["start"]
加油,你们是最棒的!