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
--treeAPI 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不匹配。

如果同时提供REPOSITORYTAG,则仅列出与该仓库和标签匹配的镜像。要查找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注册表时,pushpull命令输出包括镜像摘要。您可以使用摘要值进行pull。您也可以在createrunrmi命令中通过摘要引用,以及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.0com.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指令时,还将包含列标题。

以下示例使用没有标题的模板,并为所有镜像输出用冒号(:)分隔的IDRepository条目:

$ 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"}