如果Docker中的图像没有标记,它们是否全部使用或只是孤儿?

前端之家收集整理的这篇文章主要介绍了如果Docker中的图像没有标记,它们是否全部使用或只是孤儿?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

运行命令docker images和docker images -a会产生以下输出

  1. $docker images
  2. REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
  3. ubuntu 14.04 9cbaf023786c 2 days ago 192.8 MB
  4. $docker images -a
  5. REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
  6. ubuntu 14.04 9cbaf023786c 2 days ago 192.8 MB

图像是否标记为< none>有意义吗?如果没有:为什么他们带有我拉的标记图像?尺寸加起来还是仅仅是一种复制?如果是这样,我可以删除它们而不影响我的工作吗?

最佳答案
图像文件是独立的,并通过unionfs magic组合形成一个运行容器.
您关注的图像通常标有令人难忘的名称.
您可以删除未使用的图像,即那些对您关心的任何图像没有贡献的图像.我在bash中这样做:

  1. function docker_rm_unnamed_images {
  2. sudo docker rmi $(sudo docker images | grep '^

您可以将docker图像视为“图层”堆栈.每个Dockerfile命令都会向图像添加一个附加层.重要的是要意识到每个命令都会创建一个单独的图像文件.所以Dockerfile

  1. FROM foo
  2. RUN a
  3. RUN b
  4. RUN c

将是一堆

  1. image=1 (possibly pulled from the foo registry)
  2. image=2 (after applying a to image 1)
  3. image=3 (after applying b to image 2)
  4. image=4 (after applying c to image 3)

foo图像可能由多个其他图层组成,因此您的最终图像是4个或更多图像的堆叠.每个图像文件都存在于docker镜像注册表中.其中大多数都是未命名的,因为它们对应于例如RUN命令.每个图像文件1-4可能相当小(除非它们对应于例如yum install p1 ..p100).它们一起构成了最终运行的容器的文件系统.

猜你在找的Docker相关文章