docker image ls
描述 | 列出镜像 |
---|---|
用法 | docker image ls [OPTIONS] [REPOSITORY[:TAG]] |
别名 | docker image list docker images |
描述
默认的docker images
将显示所有顶级镜像、它们的仓库和标签以及它们的大小。
Docker镜像具有中间层,可以提高可重用性,减少磁盘使用量,并通过允许缓存每个步骤来加快docker build
的速度。默认情况下不会显示这些中间层。
SIZE
是镜像及其所有父镜像所占用的累积空间。这也是当您docker save
镜像时创建的Tar文件内容使用的磁盘空间。
如果镜像具有多个仓库名称或标签,则该镜像将列出多次。此单个镜像(可通过其匹配的IMAGE ID
识别)仅使用一次列出的SIZE
。
选项
选项 | 默认值 | 描述 |
---|---|---|
-a, --all | 显示所有镜像(默认情况下隐藏中间镜像) | |
--digests | 显示摘要 | |
-f, --filter | 根据提供的条件过滤输出 | |
--format | 使用自定义模板格式化输出 'table': 以表格格式打印输出,包含列标题(默认) 'table TEMPLATE': 使用给定的Go模板以表格格式打印输出 'json': 以JSON格式打印 'TEMPLATE': 使用给定的Go模板打印输出。 有关使用模板格式化输出的更多信息,请参考https://docs.docker.net.cn/go/formatting/ | |
--no-trunc | 不截断输出 | |
-q, --quiet | 仅显示镜像ID | |
--tree | API 1.47+ 实验性 (CLI) 将多平台镜像列为树状结构(实验性) |
示例
列出最近创建的镜像
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> 77af4d6b9913 19 hours ago 1.089 GB
committ latest b6fa739cedf5 19 hours ago 1.089 GB
<none> <none> 78a85c484f71 19 hours ago 1.089 GB
docker latest 30557a29d5ab 20 hours ago 1.089 GB
<none> <none> 5ed6274db6ce 24 hours ago 1.089 GB
postgres 9 746b819f315e 4 days ago 213.4 MB
postgres 9.3 746b819f315e 4 days ago 213.4 MB
postgres 9.3.5 746b819f315e 4 days ago 213.4 MB
postgres latest 746b819f315e 4 days ago 213.4 MB
按名称和标签列出镜像
docker images
命令接受可选的[REPOSITORY[:TAG]]
参数,该参数将列表限制为与参数匹配的镜像。如果您指定REPOSITORY
但没有TAG
,则docker images
命令将列出给定仓库中的所有镜像。
例如,要列出java
仓库中的所有镜像,请运行以下命令:
$ docker images java
REPOSITORY TAG IMAGE ID CREATED SIZE
java 8 308e519aac60 6 days ago 824.5 MB
java 7 493d82594c15 3 months ago 656.3 MB
java latest 2711b1d6f3aa 5 months ago 603.9 MB
[REPOSITORY[:TAG]]
值必须完全匹配。这意味着,例如,docker images jav
与镜像java
不匹配。
如果同时提供REPOSITORY
和TAG
,则仅列出与该仓库和标签匹配的镜像。要查找java
仓库中带有标签8
的所有本地镜像,可以使用:
$ docker images java:8
REPOSITORY TAG IMAGE ID CREATED SIZE
java 8 308e519aac60 6 days ago 824.5 MB
如果没有任何内容与REPOSITORY[:TAG]
匹配,则列表为空。
$ docker images java:0
REPOSITORY TAG IMAGE ID CREATED SIZE
列出完整长度的镜像ID(--no-trunc)
$ docker images --no-trunc
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> sha256:77af4d6b9913e693e8d0b4b294fa62ade6054e6b2f1ffb617ac955dd63fb0182 19 hours ago 1.089 GB
committest latest sha256:b6fa739cedf5ea12a620a439402b6004d057da800f91c7524b5086a5e4749c9f 19 hours ago 1.089 GB
<none> <none> sha256:78a85c484f71509adeaace20e72e941f6bdd2b25b4c75da8693efd9f61a37921 19 hours ago 1.089 GB
docker latest sha256:30557a29d5abc51e5f1d5b472e79b7e296f595abcf19fe6b9199dbbc809c6ff4 20 hours ago 1.089 GB
<none> <none> sha256:0124422dd9f9cf7ef15c0617cda3931ee68346455441d66ab8bdc5b05e9fdce5 20 hours ago 1.089 GB
<none> <none> sha256:18ad6fad340262ac2a636efd98a6d1f0ea775ae3d45240d3418466495a19a81b 22 hours ago 1.082 GB
<none> <none> sha256:f9f1e26352f0a3ba6a0ff68167559f64f3e21ff7ada60366e2d44a04befd1d3a 23 hours ago 1.089 GB
tryout latest sha256:2629d1fa0b81b222fca63371ca16cbf6a0772d07759ff80e8d1369b926940074 23 hours ago 131.5 MB
<none> <none> sha256:5ed6274db6ceb2397844896966ea239290555e74ef307030ebb01ff91b1914df 24 hours ago 1.089 GB
列出镜像摘要(--digests)
使用v2或更高版本格式的镜像具有名为digest
的内容寻址标识符。只要用于生成镜像的输入不变,摘要值就是可预测的。要列出镜像摘要值,请使用--digests
标志。
$ docker images --digests
REPOSITORY TAG DIGEST IMAGE ID CREATED SIZE
localhost:5000/test/busybox <none> sha256:cbbf2f9a99b47fc460d422812b6a5adff7dfee951d8fa2e4a98caa0382cfbdbf 4986bf8c1536 9 weeks ago 2.43 MB
推送或拉取到2.0注册表时,push
或pull
命令输出包括镜像摘要。您可以使用摘要值进行pull
。您也可以在create
、run
和rmi
命令中通过摘要引用,以及Dockerfile中的FROM
镜像引用。
过滤(--filter)
过滤标志(-f
或--filter
)格式为“key=value”。如果有多个过滤器,则传递多个标志(例如,--filter "foo=bar" --filter "bif=baz"
)。
当前支持的过滤器是:
- dangling(布尔值 - true 或 false)
- label(
label=<key>
或label=<key>=<value>
) - before(
<image-name>[:<tag>]
、<image id>
或<image@digest>
) - 过滤在给定ID或引用之前创建的镜像 - since(
<image-name>[:<tag>]
、<image id>
或<image@digest>
) - 过滤在给定ID或引用之后创建的镜像 - reference(镜像引用的模式) - 过滤其引用与指定模式匹配的镜像
显示未标记的镜像(dangling)
$ docker images --filter "dangling=true"
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> 8abc22fbb042 4 weeks ago 0 B
<none> <none> 48e5f45168b9 4 weeks ago 2.489 MB
<none> <none> bf747efa0e2f 4 weeks ago 0 B
<none> <none> 980fe10e5736 12 weeks ago 101.4 MB
<none> <none> dea752e4e117 12 weeks ago 101.4 MB
<none> <none> 511136ea3c5a 8 months ago 0 B
这将显示作为镜像树叶节点(不是中间层)的未标记镜像。当镜像的新构建将repo:tag
从镜像ID中移除时,就会出现这些镜像,将其保留为<none>:<none>
或未标记。如果尝试在容器当前正在使用镜像时移除镜像,则会发出警告。通过使用此标志,可以进行批量清理。
可以将其与docker rmi
结合使用。
$ docker rmi $(docker images -f "dangling=true" -q)
8abc22fbb042
48e5f45168b9
bf747efa0e2f
980fe10e5736
dea752e4e117
511136ea3c5a
如果存在任何正在使用这些未标记镜像的容器,Docker 将会发出警告。
显示具有给定标签的镜像
label
过滤器根据label
的存在或label
和值来匹配镜像。
以下过滤器匹配具有com.example.version
标签的镜像,无论其值如何。
$ docker images --filter "label=com.example.version"
REPOSITORY TAG IMAGE ID CREATED SIZE
match-me-1 latest eeae25ada2aa About a minute ago 188.3 MB
match-me-2 latest dea752e4e117 About a minute ago 188.3 MB
以下过滤器匹配具有值为1.0
的com.example.version
标签的镜像。
$ docker images --filter "label=com.example.version=1.0"
REPOSITORY TAG IMAGE ID CREATED SIZE
match-me latest 511136ea3c5a About a minute ago 188.3 MB
在此示例中,值为0.1
,它返回一个空集,因为没有找到匹配项。
$ docker images --filter "label=com.example.version=0.1"
REPOSITORY TAG IMAGE ID CREATED SIZE
按时间过滤镜像
before
过滤器仅显示在具有给定ID或引用的镜像之前创建的镜像。例如,具有以下镜像:
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
image1 latest eeae25ada2aa 4 minutes ago 188.3 MB
image2 latest dea752e4e117 9 minutes ago 188.3 MB
image3 latest 511136ea3c5a 25 minutes ago 188.3 MB
使用before
进行过滤将得到:
$ docker images --filter "before=image1"
REPOSITORY TAG IMAGE ID CREATED SIZE
image2 latest dea752e4e117 9 minutes ago 188.3 MB
image3 latest 511136ea3c5a 25 minutes ago 188.3 MB
使用since
进行过滤将得到:
$ docker images --filter "since=image3"
REPOSITORY TAG IMAGE ID CREATED SIZE
image1 latest eeae25ada2aa 4 minutes ago 188.3 MB
image2 latest dea752e4e117 9 minutes ago 188.3 MB
按引用过滤镜像
reference
过滤器仅显示其引用与指定模式匹配的镜像。
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
busybox latest e02e811dd08f 5 weeks ago 1.09 MB
busybox uclibc e02e811dd08f 5 weeks ago 1.09 MB
busybox musl 733eb3059dce 5 weeks ago 1.21 MB
busybox glibc 21c16b6787c6 5 weeks ago 4.19 MB
使用reference
进行过滤将得到:
$ docker images --filter=reference='busy*:*libc'
REPOSITORY TAG IMAGE ID CREATED SIZE
busybox uclibc e02e811dd08f 5 weeks ago 1.09 MB
busybox glibc 21c16b6787c6 5 weeks ago 4.19 MB
使用多个reference
进行过滤将得到匹配A或B的结果:
$ docker images --filter=reference='busy*:uclibc' --filter=reference='busy*:glibc'
REPOSITORY TAG IMAGE ID CREATED SIZE
busybox uclibc e02e811dd08f 5 weeks ago 1.09 MB
busybox glibc 21c16b6787c6 5 weeks ago 4.19 MB
格式化输出(--format)
格式化选项(--format
)将使用Go模板漂亮地打印容器输出。
Go模板的有效占位符如下所示:
占位符 | 描述 |
---|---|
.ID | 镜像ID |
.Repository | 镜像仓库 |
.Tag | 镜像标签 |
.Digest | 镜像摘要 |
.CreatedSince | 自创建镜像以来经过的时间 |
.CreatedAt | 创建镜像的时间 |
.Size | 镜像磁盘大小 |
使用--format
选项时,image
命令将完全按照模板声明的输出数据,或者在使用table
指令时,还将包含列标题。
以下示例使用没有标题的模板,并为所有镜像输出用冒号(:
)分隔的ID
和Repository
条目:
$ docker images --format "{{.ID}}: {{.Repository}}"
77af4d6b9913: <none>
b6fa739cedf5: committ
78a85c484f71: <none>
30557a29d5ab: docker
5ed6274db6ce: <none>
746b819f315e: postgres
746b819f315e: postgres
746b819f315e: postgres
746b819f315e: postgres
要以表格格式列出所有镜像及其仓库和标签,可以使用:
$ docker images --format "table {{.ID}}\t{{.Repository}}\t{{.Tag}}"
IMAGE ID REPOSITORY TAG
77af4d6b9913 <none> <none>
b6fa739cedf5 committ latest
78a85c484f71 <none> <none>
30557a29d5ab docker latest
5ed6274db6ce <none> <none>
746b819f315e postgres 9
746b819f315e postgres 9.3
746b819f315e postgres 9.3.5
746b819f315e postgres latest
要以JSON格式列出所有镜像,请使用json
指令:
$ docker images --format json
{"Containers":"N/A","CreatedAt":"2021-03-04 03:24:42 +0100 CET","CreatedSince":"5 days ago","Digest":"\u003cnone\u003e","ID":"4dd97cefde62","Repository":"ubuntu","SharedSize":"N/A","Size":"72.9MB","Tag":"latest","UniqueSize":"N/A","VirtualSize":"72.9MB"}
{"Containers":"N/A","CreatedAt":"2021-02-17 22:19:54 +0100 CET","CreatedSince":"2 weeks ago","Digest":"\u003cnone\u003e","ID":"28f6e2705743","Repository":"alpine","SharedSize":"N/A","Size":"5.61MB","Tag":"latest","UniqueSize":"N/A","VirtualSize":"5.613MB"}