Docker 子命令:
attach commit diff export history import insert kill login port
pull restart rmi save start tag version build cp events
help images info inspect load logs ps push rm run
search stop top wait
docker help: 帮助
命令格式:
docker help [COMMAND]
例子:
docker help run
docker version: 显示Docker版本
docker info: 显示Docker信息
docker attach: 挂载正在后台运行的容器到前台
命令格式:
docker attach [OPTIONS] CONTAINER
命令参数:
--no-stdin=false 不挂载输入流
--sig-proxy=true 代理接收系统信息,(除SIGCHLD\SIGKILL\SIGSTOP以外)
例子:
ID=$(sudo docker run -d -i -tubuntu /bin/bash)
sudo docker attach $ID
docker run: 在一个新的容器中执行命令 (CTRL-p CTRL-q 退出至后台运行)
请参考 http://blog.csdn.net/hyzhou33550336/article/details/41703629
命令格式:
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
例子:
sudo docker run -i -t ubuntu:14.04 /bin/bash 启动一个新的Ubuntu容器
sudo docker run --rm -i -t ubuntu:14.04/bin/bash 建议新手测试加上 -—rm
sudo docker run -i -t --name "private_container" ubuntu:14.04 /bin/bash
docker ps: 列出当前容器
命令格式:
docker ps [OPTIONS]
命令参数:
-a, --all=false 显示所有容器,包括当前没有运行的容器
--before="" 显示在某一个指定ID或Name的容器之前的容器
--since="" 显示在某一个指定ID或Name的容器之后的容器
-f, --filter=[] 按条件过滤容器, 可选的过滤选项:
exited=
容器的返回值 -l, --latest=false 显示最新的一个容器
-n num 显示最新的N个容器
--no-trunc=false 不要截断输出
-q, --quiet=false 仅显示容器ID
-s, --size=false 显示容器大小
例子:
docker ps 当前正在运行的容器
docker ps -a 当前正在运行或是停止的容器
docker ps -a -q --no-trunc 获得当前所有容器的ID,不截断输出
docker rm $(echo $(docker ps -q --no-trunc) $(dockerps -a -q--no-trunc) | sed 's|\s|\n|g' |sort | uniq -u)
删除当前不在运行状态的容器ID,也可以把前面改成docker rm
docker images: 列出当前镜像
命令格式:
docker images [OPTIONS] [NAME]
命令参数:
-a, --all=false 显示所有镜像,包括中间生成的临时镜像
-f, --filter=[] 通过标签过滤 (i.e. 'dangling=true')
--no-trunc=false 不要截断输出
-q, --quiet=false 仅显示容器ID
例子:
docker images 显示当前仓库中的镜像
docker images -a 显示当前仓库中的镜像与临时镜像
docker images -a -q --no-trunc 显示当前仓库中的镜像与临时镜像的ID,不截断输出
docker logs: 显示容器的日志
命令格式:
docker logs CONTAINER
命令参数:
-f, --follow=false 等待容器后续的输出(类似 tail -f)
-t, --timestamps=false 显示时间戳
--tail="all"
例子:
sudo docker logs 7bb0e258aefe
sudo docker logs --timestamps=true 7bb0e258aefe
sudo docker logs --timestamps=true 7bb0e258aefe > 7bb0e258aefe.log
终端A:
sudo docker logs --follow 7bb0e258aefe
终端B:
sudo docker attach 708cc7ec0f23 (随便执行一些命令可以看到终端A会有实时输出)
docker inspect: 显示镜像或容器的详细信息
命令格式:
docker inspect CONTAINER|IMAGE [CONTAINER|IMAGE...]
命令参数:
-f, --format="" 选择输出内容,--format="{{.NetworkSettings.IPAddress}}"
例子:
sudo docker inspect 7bb0e258aefe
sudo dockerinspect--format='{{.NetworkSettings.IPAddress}}' 7bb0e258aefe
docker stop: 停止运行中的容器 (CTRL-d 强制退出, Exited (0))
命令格式:
Docker stop [OPTIONS] CONTAINER [CONTAINER...]
命令参数:
-t, --time=10 杀掉容器进程之前,等待的时间
例子:
sudo docker stop 7bb0e258aefe
docker kill: 杀掉一个运行中的容器 (Exited (-1))
命令格式:
docker kill [OPTIONS] CONTAINER [CONTAINER...]
命令参数:
-s, --signal="KILL" 选择向容器发出的Signal
例子:
sudo docker kill 7bb0e258aefe
docker start: 重启停止的容器
命令格式:
Docker start CONTAINER [CONTAINER...]
命令参数:
-a,--attach=false Attach container'sSTDOUT and STDERR and forward allsignals to the process
-i,--interactive=false Attach container'sSTDIN
例子:
sudo docker start 7bb0e258aefe
docker restart: 重启运行中的容器
命令格式:
docker restart [OPTIONS] CONTAINER [CONTAINER...]
命令参数:
-t, --time=10 杀掉容器进程之前,等待的时间
例子:
sudo docker restart 7bb0e258aefe
docker wait: 等待容器退出
命令格式:
docker wait CONTAINER [CONTAINER...]
例子:
A终端:
sudo docker wait 708cc7ec0f23 A终端阻塞,等待容器关闭
B终端:
sudo docker restart 708cc7ec0f23 从B终端关闭容器,A终端显示0,结束阻塞,返回
docker cp: 拷贝容器中的文件
命令格式:
docker cp CONTAINER:PATH HOSTPATH
例子:
docker cp c3f279d17e0a:/home/hyzhou/answer.txt . 将镜像中的/home/hyzhou/answer.txt文件拷贝到当前目录下
docker rm: 删除容器
命令格式:
docker rm [OPTIONS] CONTAINER [CONTAINER...]
命令参数:
-f, --force=false 强制删除容器(使用SIGKILL)
-l, --link=false Removethe specified link and not the underlyingcontainer
-v, --volumes=false Removethe volumes associated with the container
例子:
docker rm my_ubuntu 删除容器
docker rm 708cc7ec0f23 删除容器
docker rm $(docker ps -a -q) 删除所有容器
docker top: 查看容器输出
命令格式:
docker top CONTAINER [ps OPTIONS]
例子:
[ps OPTIONS]的意思是, 你可以在这个命令后面加上使用ps命令时的各种参数
sudo docker top 708cc7ec0f23
sudo docker top 708cc7ec0f23 aux
docker events: 实时监听容器的事件
命令格式:
docker events [OPTIONS]
命令参数:
--since="" 显示某一个时间戳之后的events
--until="" 实时监听到某个时间戳为止
例子:
A终端:
sudo docker events 终端A等待Docker系统信息
sudo docker events --since 1378216169
sudo docker events --since '2013-09-03'
sudo docker events--since '2013-09-03 15:49:29'
sudo docker events --since'2013-09-03 15:49:29 +0200CEST'
sudo docker events > docker.log & 后台记录Docker的容器事件
B终端:
sudo docker restart 708cc7ec0f23 从B终端关闭容器
A终端显示:
2014-09-06T23:08:21+08:00708cc7ec0f23a5ec898c9d6308e9767edb66b863e96352ca6e030f0a5557f3b2:(fromubuntu:latest) die
2014-09-06T23:08:22+08:00708cc7ec0f23a5ec898c9d6308e9767edb66b863e96352ca6e030f0a5557f3b2:(fromubuntu:latest) start
2014-09-06T23:08:22+08:00708cc7ec0f23a5ec898c9d6308e9767edb66b863e96352ca6e030f0a5557f3b2:(fromubuntu:latest) restart
docker history: 显示镜像的历史记录
命令格式:
docker history [OPTIONS] IMAGE
命令参数:
--no-trunc=false 不要截断输出
-q, --quiet=false 仅显示容器ID
docker search: 在Docker Hub上寻找镜像
命令格式:
docker search TERM
命令参数:
--automated=false 使用Github或BitBucket的源代码自动构建
--no-trunc=false 不要截断输出
-s, --stars=0 只显示Star数量超过N的镜像
例子:
docker search --starts=10 ubuntu
docker pull: 从远程拉取镜像
命令格式:
docker pull NAME[:TAG]
例子:
docker pull ubuntu:latest
docker push: 推送镜像到远程仓库
命令格式:
docker push NAME[:TAG]
例子:
docker push hyzhou/ubuntu:3.2.3
docker diff: 列出镜像中文件和目录的变化
命令格式:
docker diff CONTAINER
命令输出: 输出一共有三种
A- Add
D- Delete
C- Change
例子:
diff显示的是镜像和当前运行的容器之间的区别,所以diff的基础是IMAGE
下面例子中的b705fc4f4a50和708cc7ec0f23,内容其实是一样的
sudo docker ps -a
CONTAINERID IMAGE COMMAND CREATED STATUS
b705fc4f4a50 new:latest "/bin/bash" 49 seconds ago Up 49 seconds
708cc7ec0f23 ubuntu:latest "/bin/bash" 9 minutes ago Up 9 minutes
sudo docker diff 7bb0e258aefe
C/root
A/root/new.txt
sudo docker diff b705fc4f4a50
docker commit: 将容器打包成新的镜像
命令格式:
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
命令参数:
-a, --author="" 作者信息,"John Hannibal Smith
" -m, --message="" 提交信息
-p, --pause=true 在提交镜像时暂停容器
例子:
sudo docker ps
ID IMAGE COMMAND CREATED STATUS
c3f279d17e0a ubuntu:12.04 /bin/bash 7 days ago Up 25 hours
197387f1b436 ubuntu:12.04 /bin/bash 7 days ago Up 25 hours
docker commitc3f279d17e0a Hyzhou/my_ubuntu:3.2.3
docker commit -a "Hyzhou
" -m "addthe new software" c3f279d17e0aHyzhou/my_ubuntu:3.2.3docker images
REPOSITORY TAG ID CREATED VIRTUAL SIZE
Hyzhou/my_ubuntu 3.2.3 f5283438590d 16 seconds ago 335.7 MB
docker build: 使用Dockerfile构建新镜像
命令格式:
docker build [OPTIONS] PATH|URL|-
命令参数:
--force-rm=false 移除构建时生成的中间容器
--no-cache=false Donot use cache when building the image
-q, --quiet=false 不显示容器的输出
--rm=true 构建成功后,移除构建时生成的中间容器
-t, --tag="" 构建成功后,新建镜像的名称
docker tag: 为镜像加上标签
命令格式:
docker tag [OPTIONS] IMAGE[:TAG][REGISTRYHOST/][USERNAME/]NAME[:TAG]
命令参数:
-f, --force=false 强制打上标签?
例子:
sudo docker tag ubuntu:latest hyzhou/my_ubuntu:3.2.3 给ubuntu:latest打上新TAG:hyzhou/my_ubuntu:3.2.3
sudo dockertag eb601b8965b8 ubuntu:latest 给eb601b8965b8镜像打上TAG: ubuntu:latest(会转换原有的TAG指向)
docker save: 将image保存为tar压缩文件
命令格式:
docker save [OPTIONS] IMAGE [IMAGE...]
命令参数:
-o, --output="" 写入到一个文件中作为输出,默认是标准输出流
例子:
docker save --output ubuntu.tar ubuntu:latest 将Ubuntu的最新镜像打包为ubuntu.tar
docker save ubuntu:latest > ubuntu.tar 将Ubuntu的最新镜像打包为ubuntu.tar
docker load: 将tar压缩文件保存为image
命令格式:
Docker load [OPTIONS]
命令参数:
-i, --input="" 读取一个压缩文件作为输入,默认是标准输入流
例子:
docker load --input ubuntu.tar 读取ubuntu.tar作为镜像
docker load < ubuntu.tar 读取ubuntu.tar作为镜像
docker export: 把容器系统文件打包并导出来,方便分发给其他场景使用。
命令格式:
docker export CONTAINER
例子:
sudo docker export my_ubuntu > ubuntu.tar 将Ubuntu的最新镜像打包为ubuntu.tar
docker import: 加载容器系统文件
命令格式:
docker import URL|- [REPOSITORY[:TAG]]
例子:
sudo docker import http://example.com/exampleimage.tgz
cat exampleimage.tgz | sudodocker import -exampleimagelocal:new