转载:Docker命令详解

转自:https://www.cnblogs.com/ivictor/archive/2015/09/08/4791274.html

docker --help

Usage: docker [OPTIONS] COMMAND [arg...]
docker daemon [ --help | ... ]
docker [ -h | --help | -v | --version ]

A self-sufficient runtime for containers.

Options:

--config=~/.docker Location of client config files
-D, --debug=false Enable debug mode
-H, --host=[] Daemon socket(s) to connect to
-h, --help=false Print usage
-l, --log-level=info Set the logging level
--tls=false Use TLS; implied by --tlsverify
--tlscacert=~/.docker/ca.pem Trust certs signed only by this CA
--tlscert=~/.docker/cert.pem Path to TLS certificate file
--tlskey=~/.docker/key.pem Path to TLS key file
--tlsverify=false Use TLS and verify the remote
-v, --version=false Print version information and quit

Commands:
attach Attach to a running container
--将终端依附到容器上
1> 运行一个交互型容器
[root@localhost ~]# docker run -i -t centos /bin/bash
[root@f0a02b473067 /]#
2> 在另一个窗口上查看该容器的状态
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a75f165ce6 centos "/bin/bash" 5 seconds ago Up 5 seconds cranky_mahavira
3> 退出第一步中运行的容器
[root@d4a75f165ce6 /]# exit
exit
4> 查看该容器的状态
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a75f165ce6 centos "/bin/bash" 2 minutes ago Exited (0) 23 seconds ago cranky_mahavira
可见此时容器的状态是Exited,那么,如何再次运行这个容器呢?可以使用docker start命令
5> 再次运行该容器
[root@localhost ~]# docker start cranky_mahavira
cranky_mahavira
6> 再次查看该容器的状态
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a75f165ce6 centos "/bin/bash" 6 minutes ago Up 29 seconds cranky_mahavira
因为该容器是交互型的,但此刻我们发现没有具体的终端可以与之交互,这时可使用attach命令。
7> 通过attach命令进行交互
[root@localhost ~]# docker attach cranky_mahavira
[root@d4a75f165ce6 /]#

build     Build an image from a Dockerfile
          --通过Dockerfile创建镜像

commit    Create a new image from a container's changes
          --通过容器创建本地镜像
          注意:如果是要push到docker hub中,注意生成镜像的命名
           [root@localhost ~]# docker commit centos_v1 centos:v1
           68ad49c999496cff25fdda58f0521530a143d3884e61bce7ada09bdc22337638
           [root@localhost ~]# docker push centos:v1
           You cannot push a "root" repository. Please rename your repository to <user>/<repo> (ex: <user>/centos)
           用centos:v1就不行,因为它push到docker hub中时,是推送到相应用户下,必须指定用户名。譬如我的用户名是ivictor,则新生成的本地镜像命名为:
           docker push victor/centos:v1,其中v1是tag,可不写,默认是latest 
          
cp        Copy files/folders from a container to a HOSTDIR or to STDOUT
          --在宿主机和容器之间相互COPY文件
          cp的用法如下:
          Usage:    docker cp [OPTIONS] CONTAINER:PATH LOCALPATH|-
                    docker cp [OPTIONS] LOCALPATH|- CONTAINER:PATH
          如:容器mysql中/usr/local/bin/存在docker-entrypoint.sh文件,可如下方式copy到宿主机
          #  docker cp mysql:/usr/local/bin/docker-entrypoint.sh /root
          修改完毕后,将该文件重新copy回容器
          # docker cp /root/docker-entrypoint.sh mysql:/usr/local/bin/     

create    Create a new container  
          --创建一个新的容器,注意,此时,容器的status只是Created

diff      Inspect changes on a container's filesystem
          --查看容器内发生改变的文件,以我的mysql容器为例
           [root@localhost ~]# docker diff mysqldb
           C /root
           A /root/.bash_history
           A /test1.txt
           A /test.tar
           A /test.txt
           C /run
           C /run/mysqld
           A /run/mysqld/mysqld.pid
           A /run/mysqld/mysqld.sock
           不难看出,C对应的均是目录,A对应的均是文件

events    Get real time events from the server
          --实时输出Docker服务器端的事件,包括容器的创建,启动,关闭等。
          譬如:
          [root@localhost ~]# docker events
          2015-09-08T17:40:13.000000000+08:00 d2a2ef5ddb90b505acaf6b59ab43eecf7eddbd3e71f36572436c34dc0763db79: (from wordpress) create
          2015-09-08T17:40:14.000000000+08:00 d2a2ef5ddb90b505acaf6b59ab43eecf7eddbd3e71f36572436c34dc0763db79: (from wordpress) die
          2015-09-08T17:42:10.000000000+08:00 839866a338db6dd626fa8eabeef53a839e4d2e2eb16ebd89679aa722c4caa5f7: (from mysql) start

exec      Run a command in a running container
          --用于容器启动之后,执行其它的任务
          通过exec命令可以创建两种任务:后台型任务和交互型任务
          后台型任务:docker exec -d cc touch 123  其中cc是容器名
          交互型任务:
          [root@localhost ~]# docker exec -i -t cc /bin/bash
          root@1e5bb46d801b:/# ls

bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var

export    Export a container's filesystem as a tar archive
          --将容器的文件系统打包成tar文件
          有两种方式:
          docker export -o mysqldb1.tar mysqldb
          docker export mysqldb > mysqldb.tar

history   Show the history of an image
          --显示镜像制作的过程,相当于dockfile

images    List images   
          --列出本机的所有镜像

import    Import the contents from a tarball to create a filesystem image
          --根据tar文件的内容新建一个镜像,与之前的export命令相对应
         [root@localhost ~]# docker import mysqldb.tar mysql:v1
         eb81de183cd94fd6f0231de4ff29969db822afd3a25841d2dc9cf3562d135a10
         [root@localhost ~]# docker images
         REPOSITORY                 TAG                 IMAGE ID            CREATED              VIRTUAL SIZE
         mysql                      v1                  eb81de183cd9        21 seconds ago       281.9 MB

info      Display system-wide information
          --查看docker的系统信息
          [root@localhost ~]# docker info
          Containers: 3    --当前有3个容器
          Images: 298      
          Storage Driver: devicemapper
           Pool Name: docker-253:0-34402623-pool
           Pool Blocksize: 65.54 kB
           Backing Filesystem: xfs
           Data file: /dev/loop0
           Metadata file: /dev/loop1
           Data Space Used: 8.677 GB     --对应的是下面Data loop file大小
           Data Space Total: 107.4 GB
           Data Space Available: 5.737 GB
           Metadata Space Used: 13.4 MB  --对应的是下面Metadata loop file大小
           Metadata Space Total: 2.147 GB
           Metadata Space Available: 2.134 GB
           Udev Sync Supported: true
           Deferred Removal Enabled: false
           Data loop file: /var/lib/docker/devicemapper/devicemapper/data
           Metadata loop file: /var/lib/docker/devicemapper/devicemapper/metadata
           Library Version: 1.02.93-RHEL7 (2015-01-28)
          Execution Driver: native-0.2
          Logging Driver: json-file
          Kernel Version: 3.10.0-229.el7.x86_64
          Operating System: CentOS Linux 7 (Core)
          CPUs: 2
          Total Memory: 979.7 MiB
          Name: localhost.localdomain
          ID: TFVB:BXGQ:VVOC:K2DJ:LECE:2HNK:23B2:LEVF:P3IQ:L7D5:NG2V:UKNL
          WARNING: bridge-nf-call-iptables is disabled
          WARNING: bridge-nf-call-ip6tables is disabled

inspect   Return low-level information on a container or image
          --用于查看容器的配置信息,包含容器名、环境变量、运行命令、主机配置、网络配置和数据卷配置等。

kill      Kill a running container 
          --强制终止容器
          关于stop和kill的区别,docker stop命令给容器中的进程发送SIGTERM信号,默认行为是会导致容器退出,当然,
          容器内程序可以捕获该信号并自行处理,例如可以选择忽略。而docker kill则是给容器的进程发送SIGKILL信号,该信号将会使容器必然退出。

load      Load an image from a tar archive or STDIN
          --与下面的save命令相对应,将下面sava命令打包的镜像通过load命令导入

login     Register or log in to a Docker registry
          --登录到自己的Docker register,需有Docker Hub的注册账号
          [root@localhost ~]# docker login
          Username: ivictor
          Password: 
          Email: xxxx@foxmail.com
          WARNING: login credentials saved in /root/.docker/config.json
          Login Succeeded

logout    Log out from a Docker registry
          --退出登录
          [root@localhost ~]# docker logout
          Remove login credentials for https://index.docker.io/v1/

logs      Fetch the logs of a container
          --用于查看容器的日志,它将输出到标准输出的数据作为日志输出到docker logs命令的终端上。常用于后台型容器

pause     Pause all processes within a container
          --暂停容器内的所有进程,
          此时,通过docker stats可以观察到此时的资源使用情况是固定不变的,
          通过docker logs -f也观察不到日志的进一步输出。

port      List port mappings or a specific mapping for the CONTAINER
          --输出容器端口与宿主机端口的映射情况
          譬如:
          [root@localhost ~]# docker port blog
          80/tcp -> 0.0.0.0:80
          容器blog的内部端口80映射到宿主机的80端口,这样可通过宿主机的80端口查看容器blog提供的服务

ps        List containers  
          --列出所有容器,其中docker ps用于查看正在运行的容器,ps -a则用于查看所有容器。

pull      Pull an image or a repository from a registry
          --从docker hub中下载镜像

push      Push an image or a repository to a registry
          --将本地的镜像上传到docker hub中
          前提是你要先用docker login登录上,不然会报以下错误
          [root@localhost ~]# docker push ivictor/centos:v1
          The push refers to a repository [docker.io/ivictor/centos] (len: 1)
          unauthorized: access to the requested resource is not authorized

rename    Rename a container
          --更改容器的名字

restart   Restart a running container 
          --重启容器

rm        Remove one or more containers 
          --删除容器,注意,不可以删除一个运行中的容器,必须先用docker stop或docker kill使其停止。
          当然可以强制删除,必须加-f参数
          如果要一次性删除所有容器,可使用 docker rm -f `docker ps -a -q`,其中,-q指的是只列出容器的ID

rmi       Remove one or more images   
          --删除镜像

run       Run a command in a new container   
          --让创建的容器立刻进入运行状态,该命令等同于docker create创建容器后再使用docker start启动容器

save      Save an image(s) to a tar archive
          --将镜像打包,与上面的load命令相对应
          譬如:
          docker save -o nginx.tar nginx

search    Search the Docker Hub for images   
          --从Docker Hub中搜索镜像

start     Start one or more stopped containers
          --启动容器

stats     Display a live stream of container(s) resource usage statistics
          --动态显示容器的资源消耗情况,包括:CPU、内存、网络I/O

stop      Stop a running container 
          --停止一个运行的容器

tag       Tag an image into a repository
          --对镜像进行重命名

top       Display the running processes of a container
          --查看容器中正在运行的进程

unpause   Unpause all processes within a container
          --恢复容器内暂停的进程,与pause参数相对应

version   Show the Docker version information 
          --查看docker的版本

wait      Block until a container stops, then print its exit code
          --捕捉容器停止时的退出码
          执行此命令后,该命令会“hang”在当前终端,直到容器停止,此时,会打印出容器的退出码。

Run 'docker COMMAND --help' for more information on a command.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容