docker ps是我们操作容器次数最多的命令之一,但我们往往使用docker ps或是docker ps -a,对于该命令的其它选项,我们关注比较少。那么这一讲,我给大家详细讲讲该命令的全部方法。

命令:

docker container ls

描述:

列出容器。

用法:

docker container ls [OPTIONS]

别名:

docker ps、docker container ps、docker container list(docker的一些命令具有别名,这四种别名是等价的,都可以使用,建议使用最简短的docker ps)

选项:

选项描述
-a, –all显示所有容器(默认只显示正在运行的容器)
-f, –filter根据提供的条件过滤输出
–format使用自定义模板格式化输出: 
‘table’:以表格格式打印输出,包含列标题(默认) 
‘table TEMPLATE’:使用给定的 Go 模板以表格格式打印输出 
‘json’:以 JSON 格式打印 
‘TEMPLATE’:使用给定的 Go 模板打印输出。 
-n, –last显示最后创建的 n 个容器(包括所有状态),默认值-1
-l, –latest显示最新创建的容器(包括所有状态)
–no-trunc不要截断输出
-q, –quiet只显示容器ID
-s, –size显示总文件大小

示例1:默认命令docker ps

docker ps

输入命令之后,结果如下图所示:

可以看出,所有状态(STATUS)为Up的容器信息全部显示出来。Up状态代表运行中。

示例2:-a、–all选项

docker ps --all

命令加上–all选项,显示所有容器,包含所有状态的容器。

上图的结果显示,Exited状态的容器hardcore_benz也显示出来了。

示例3:-f, –filter选项

–filter(或 -f)标志的格式是键=值对。如果有多个过滤器,则传递多个标志(例如 –filter “foo=bar” –filter “bif=baz”)。
当前支持的过滤器有:

过滤器描述
id容器ID
name容器名称
label一个任意字符串,代表一个键或者一个键值对。表示为<key> 或 <key>=<value>。
exited一个整数,代表容器的退出码。仅在与 –all 选项一起使用时才有意义。
status其中一个状态为 created(已创建)、restarting(正在重启)、running(正在运行)、removing(正在移除)、paused(已暂停)、exited(已退出)或 dead(已死亡)。
ancestor筛选出共享给定镜像作为祖先的容器。表示为<image-name>[:<tag>]、<image id>或<image@digest>
before 或 since筛选在给定容器 ID 或名称之前或之后创建的容器
volume筛选挂载了给定卷或绑定挂载的正在运行的容器。
network筛选连接到给定网络的正在运行的容器。
publish 或 expose筛选发布或暴露给定端口的容器。表示为<port>[/<proto>]或<startport-endport>/[<proto>]
health根据容器的健康检查状态筛选容器。可能的状态有 starting(启动中)、healthy(健康)、unhealthy(不健康)或 none(无)。
isolation仅适用于 Windows 守护进程。值为 default、process 或 hyperv 之一。
is-task筛选作为服务“任务”的容器。布尔选项(true 或 false)。

这个选项因为需要很多附加条件,我只给出能直接看出效果的示例。

docker ps -f status=exited

这个选项只过滤出状态为exited(退出)的容器。

示例4:–format选项

该选项以适合自己的格式输出,其中按照Go模板的方式会涉及到以下占位符:

占位符描述
.ID容器ID
.Image镜像ID
.Command引用的命令
.CreatedAt容器创建的时间
.RunningFor自容器启动以来的经过时间。
.Ports暴露的端口。
.State容器状态(例如:”created”(已创建)、”running”(运行中)、”exited”(已退出))。
.Status容器状态,包括持续时间与健康状态的详细信息。
.Size容器磁盘大小
.Names容器名称
.Labels分配给容器的所有标签。
.Label此容器特定标签的值。例如 ‘{{.Label “com.docker.swarm.cpu”}}’
.Mounts在此容器中挂载的卷的名称。
.Networks连接到这个容器的网络的名称。

这个选项可以随便组合占位符,我每种类型只列举一个,剩下的由大家自己去玩。

docker ps  --format "table {{.Names}}\t{{.Size}}\t{{.Status}}"

这个以表格形式打印。

docker ps --format json

这个是json格式,看起来非常乱。

docker ps --format "{{.ID}}: {{.Command}} {{.RunningFor}}"

这是使用Go模板的方式打印。

示例5:-n, –last选项

docker ps -n 3

该选项后面必须加一个数字,否则会报错。该选项显示-n后面数字个容器,无论容器处于什么状态。

以下是我的阿里云上最后创建的3个容器。其中mymongo是退出状态,其它两个是运行状态。

示例6:-l, –latest选项

docker ps -l

该选项显示最新创建的容器,无论该容器处于什么状态。下面显示的是我刚刚停止的容器mymongo,使用-l选项,即便是Exited状态,也会显示。

示例7:–no-trunc选项

docker ps --no-trunc

执行该命令后,CONTAINER ID一列符号变长了。

示例8:-q, –quiet选项

docker ps -q

该选项只用来显示容器ID,想不到这个选项的实际作用,难道只是怕污了眼睛而过滤大量信息?

如图所示,只显示容器ID,并不能知道这一堆符号是什么容器。

该选项可以和–no-trunc连用,执行结果如下所示:

示例9:-s, –size选项

docker ps -s

加入该选项后,容器列表的最右侧增加SIZE列,显示两种不同的磁盘容量大小。

其中,前面的数字表示用于每个容器的可写层的磁盘数据量。 后面括号中“virtual” 表示的是容器使用的只读镜像数据以及可写层所用的磁盘空间总量。多个容器可能会共享一些或全部的只读镜像数据。从同一镜像启动的两个容器共享 100% 的只读数据,而具有共同层的不同镜像的两个容器则共享这些共同层。因此,不能简单地将虚拟大小相加。这可能会大大高估总磁盘使用量。

所有正在运行的容器在磁盘上使用的总磁盘空间是每个容器的 size 和 virtual size 值的组合。如果多个容器从完全相同的镜像启动,这些容器的总磁盘大小将是容器的总和(size of containers)加上一个镜像大小(virtual size – size)。

以上显示的磁盘空间占用情况,不包括以下五种方式:

  • 日志驱动程序存储的日志文件所占用的磁盘空间。如果容器生成大量日志数据并且没有配置日志轮换,这可能会相当可观。
  • 容器使用的卷和绑定挂载。
  • 用于容器的配置文件的磁盘空间,这些文件通常很小。
  • 写入磁盘的内存(如果启用了交换)。
  • 检查点,如果你使用实验性的检查点/恢复功能。
Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐