@zhaikun
2016-12-28T10:16:35.000000Z
字数 3474
阅读 1070
docker
docker images
命令。
[root@zzk ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/centos centos7.3.1611 67591570dd29 10 days ago 191.8 MB
docker.io/centos latest 67591570dd29 10 days ago 191.8 MB
docker.io/bash latest ee8b1affc91f 5 weeks ago 12.97 MB
[root@zzk ~]#
列表包含了仓库名、标签、镜像ID、创建时间以及所占用的空间。
镜像 ID 则是镜像的唯一标识,一个镜像可以对应多个标签。因此,在上面的例子中,我们可以看到 centos7.3.1611 和 latest 拥有相同的 ID,因为它们对应的是同一个镜像。
如果仔细观察,会注意到,这里标识的所占用空间和在 Docker Hub 上看到的镜像大小不同。比如,centos7.3.1611 镜像大小,在这里是 191 MB,但是在 Docker Hub 显示的却是 10 MB。这是因为 Docker Hub 中显示的体积是压缩后的体积。在镜像下载和上传过程中镜像是保持着压缩状态的,因此 Docker Hub 所显示的大小是网络传输中更关心的流量大小。而 docker images 显示的是镜像下载到本地后,展开的大小,准确说,是展开后的各层所占空间的总和,因为镜像到本地后,查看空间的时候,更关心的是本地磁盘空间占用的大小。
另外一个需要注意的问题是,docker images 列表中的镜像体积总和并非是所有镜像实际硬盘消耗。由于 Docker 镜像是多层存储结构,并且可以继承、复用,因此不同镜像可能会因为使用相同的基础镜像,从而拥有共同的层。由于 Docker 使用 Union FS,相同的层只需要保存一份即可,因此实际镜像硬盘占用空间很可能要比这个列表镜像大小的总和要小的多。
<none>
的镜像命名为虚悬镜像
<none> <none> 00285df0df87 5 days ago 342 MB
<div class="md-section-divider"></div>
这个镜像原本是有镜像名和标签的,原来为mongo:3.2
,随着官方镜像维护,发布了新版本后,重新 docker pull mongo:3.2
时,mongo:3.2
这个镜像名被转移到了新下载的镜像身上,而旧的镜像上的这个名称则被取消,从而成为了 <none>
。除了 docker pull
可能导致这种情况,docker build
也同样可以导致这种现象。由于新旧镜像同名,旧镜像名称被取消,从而出现仓库名、标签均为 <none>
的镜像。这类无标签镜像也被称为 虚悬镜像(dangling image) ,可以用下面的命令专门显示这类镜像:
docker images -f dangling=true
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> 00285df0df87 5 days ago 342 MB
<div class="md-section-divider"></div>
一般来说,虚悬镜像已经失去了存在的价值,是可以随意删除的,可以用下面的命令删除。
docker rmi $(docker images -q -f dangling=true)
<div class="md-section-divider"></div>
为了加速镜像构建、重复利用资源,Docker 会利用 中间层镜像。所以在使用一段时间后,可能会看到一些依赖的中间层镜像。默认的 docker images
列表中只会显示顶层镜像,如果希望显示包括中间层镜像在内的所有镜像的话,需要加 -a
参数。
docker images -a
<div class="md-section-divider"></div>
这样会看到很多无标签的镜像,与之前的虚悬镜像不同,这些无标签的镜像很多都是中间层镜像,是其它镜像所依赖的镜像。这些无标签镜像不应该删除,否则会导致上层镜像因为依赖丢失而出错。实际上,这些镜像也没必要删除,因为之前说过,相同的层只会存一遍,而这些镜像是别的镜像的依赖,因此并不会因为它们被列出来而多存了一份,无论如何你也会需要它们。只要删除那些依赖它们的镜像后,这些依赖的中间层镜像也会被连带删除。
不加任何参数的情况下,docker images
会列出所有顶级镜像,但是有时候我们只希望列出部分镜像。docker images
有好几个参数可以帮助做到这个事情。
根据仓库名列出镜像
[root@zzk ~]# docker images centos
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/centos centos7.3.1611 67591570dd29 10 days ago 191.8 MB
docker.io/centos latest 67591570dd29 10 days ago 191.8 MB
[root@zzk ~]#
<div class="md-section-divider"></div>
列出特定的某个镜像,也就是说指定仓库名和标签
[root@zzk ~]# docker images centos:centos7.3.1611
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/centos centos7.3.1611 67591570dd29 10 days ago 191.8 MB
[root@zzk ~]#
<div class="md-section-divider"></div>
除此以外,docker images
还支持强大的过滤器参数 --filter
,或者简写 -f
。之前我们已经看到了使用过滤器来列出虚悬镜像的用法,它还有更多的用法。
默认情况下,docker images
会输出一个完整的表格,但是我们并非所有时候都会需要这些内容。比如,刚才删除虚悬镜像的时候,我们需要利用 docker images
把所有的虚悬镜像的 ID 列出来,然后才可以交给 docker rmi
命令作为参数来删除指定的这些镜像,这个时候就用到了 -q
参数。
[root@zzk ~]# docker images -q
67591570dd29
67591570dd29
47bd812c12f6
ee8b1affc91f
c8c29d842c09
[root@zzk ~]#
<div class="md-section-divider"></div>
--filter
配合 -q
产生出指定范围的 ID 列表,然后送给另一个 docker
命令作为参数,从而针对这组实体成批的进行某种操作的做法在 Docker 命令行使用过程中非常常见,不仅仅是镜像,将来我们会在各个命令中看到这类搭配以完成很强大的功能。因此每次在文档看到过滤器后,可以多注意一下它们的用法。
另外一些时候,我们可能只是对表格的结构不满意,希望自己组织列;或者不希望有标题,这样方便其它程序解析结果等,这就用到了 Go 的模板语法。
比如,下面的命令会直接列出镜像结果,并且只包含镜像ID和仓库名:
[root@zzk ~]# docker images --format "{{.ID}}: {{.Repository}}"
67591570dd29: docker.io/centos
67591570dd29: docker.io/centos
47bd812c12f6: docker.io/tomcat
ee8b1affc91f: docker.io/bash
c8c29d842c09: docker.io/nginx
[root@zzk ~]#
<div class="md-section-divider"></div>
或者打算以表格等距显示,并且有标题行,和默认一样,不过自己定义列:
[root@zzk ~]# docker images --format "table {{.ID}}\t{{.Repository}}\t{{.Tag}}"
IMAGE ID REPOSITORY TAG
67591570dd29 docker.io/centos centos7.3.1611
67591570dd29 docker.io/centos latest
47bd812c12f6 docker.io/tomcat 8.0
ee8b1affc91f docker.io/bash latest
c8c29d842c09 docker.io/nginx 1.9
[root@zzk ~]#