镜像删除的Untagged 和 Deleted

Untagged: ubuntu:14.04

Deleted: sha256:a8e78858b03ba02c3df71d555f90057f890495aabc86e7a39396c68c87ed5ff2

当我们在docker中执行docker images命令查看到一些不想使用的镜像或容器时,会执行docker rmi -f xxx来对相应的目标进行删除操作,但相应的命令执行完成后会出现上面的两种情况,一种是删除成功,另一种则只是将镜像对应的标签解除了,所以二者有何区别呢?

Untagged 和 Deleted

Untagged

我们首先都知道镜像的唯一标识是其 ID 和摘要,但一个镜像可以有多个标签
因此当我们使用上面命令删除镜像的时候,实际上是在要求删除某个标签的镜像。所以首先需要做的是将满足我们要求的所有镜像标签都取消,这就是我们看到的 Untagged 的信息。因为一个镜像可以对应多个标签,因此当我们删除了所指定的标签后,可能还有别的标签指向了这个镜像,如果是这种情况,那么 Delete 行为就不会发生。所以并非所有的 docker rmi 都会产生删除镜像的行为,有可能仅仅是取消了某个标签而已。

Delated

当一个镜像所有的标签都被取消了,该镜像很可能会失去了存在的意义,因此会触发删除行为。镜像是多层存储结构,因此在删除的时候也是从上层向基础层方向依次进行判断删除。镜像的多层结构让镜像复用变动非常容易,因此很有可能某个其它镜像正依赖于当前镜像的某一层。这种情况,依旧不会触发删除该层的行为。直到没有任何层依赖当前层时,才会真实的删除当前层。所以delated命令触发的判断机制要比untagged要难上许多。

用 docker images 命令来配合

像其它可以承接多个实体的命令一样,可以使用 docker images -q 来配合使用 docker rmi,这样可以成批的删除希望删除的镜像。比如删除虚悬镜像的指令是:

$ docker rmi $(docker images -q -f dangling=true)

比如,我们需要删除所有仓库名为 redis 的镜像:

$ docker rmi $(docker images -q redis)

或者删除所有在 mongo:3.2 之前的镜像:

$ docker rmi $(docker images -q -f before=mongo:3.2)
Logo

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

更多推荐