写点什么

Docker 镜像列表中的 none:none 是什么

作者:程序员欣宸
  • 2022 年 9 月 23 日
    广东
  • 本文字数:6049 字

    阅读完需:约 20 分钟

Docker镜像列表中的none:none是什么

欢迎访问我的 GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos

本篇概览

  • 在构建过 Docker 镜像的电脑上查看本地镜像列表,有可能看到下图红框中的镜像,在列表中展示为<none>:<none>


  • 这种镜像在 Docker 官方文档中被称作 dangling images ,指的是没有标签并且没有被容器使用的镜像。

官方解释

怎么来的

  • 结合第一幅图,梳理一下 dangling images 怎么产生的:


  1. 第一次构建镜像时生成的镜像 ID 为 079dbd67f9f4,此镜像会被构建工具加上标签 bolingcavalry/eureka-server:0.0.1-SNAPSHOT;

  2. 第二次构建镜像时生成的镜像 ID 为 e40a97f764ef,此镜像会被构建工具加上标签 bolingcavalry/eureka-server:0.0.1-SNAPSHOT,

  3. Docker 会移除 079dbd67f9f4 的标签,此时 079dbd67f9f4 就变成了 dangling images,在镜像列表中展示为<none>:<none>

准备实战

  • 接下来通过实际操作来复现此问题,并做一些有趣的测试;

  • 操作的主要内容是将一个 maven 工程构建成 Docker 镜像,以下是环境信息:


  1. 操作系统:Ubuntu 18.04.2 LTS

  2. Docker:18.06.1-ce

  3. Java:1.8.0_191

  4. Maven:3.6.0

实战源码下载

  • 如果您不想写代码,也可以在 Github 下载整个 maven 工程,地址和链接信息如下表所示:



  • 这个 git 项目中有多个文件夹,本章源码在 springcloudscaledemo 这个文件夹下,如下图红框所示:


  • springcloudscaledemo 文件夹内有三个工程,本次实战用到的是 eureka-server,如下图:


实战操作

  • 接下来一起开发一个简单的 java 项目:

  • 基于 Maven 创建一个 springboot 工程,pom.xml 内容如下,主要注意 plugins 节点中的插件,该插件是用来构建镜像的:


<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>
<groupId>com.bolingcavalry</groupId> <artifactId>eureka-server</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging>
<name>eureka-server</name> <description>Demo project for Spring Boot</description>
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent>
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <spring-cloud.version>Edgware.SR1</spring-cloud.version> </properties>
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency>
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin>
<!--新增的docker maven插件--> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>0.4.12</version> <!--docker镜像相关的配置信息--> <configuration> <!--镜像名,这里用工程名--> <imageName>bolingcavalry/${project.artifactId}</imageName> <!--TAG,这里用工程版本号--> <imageTags> <imageTag>${project.version}</imageTag> </imageTags> <!--镜像的FROM,使用java官方镜像--> <baseImage>java:8u111-jdk</baseImage> <!--该镜像的容器启动后,直接运行spring boot工程--> <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint> <!--构建镜像的配置信息--> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin> </plugins> </build></project>
复制代码


  • application.properties 内容如下,可见该应用其实就是 springcloud 中的 eureka 身份:


server.port=8080
eureka.instance.hostname=localhosteureka.client.register-with-eureka=falseeureka.client.fetch-registry=falseeureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
复制代码


  • 启动类是 EurekaServerApplication,内容如下:


@SpringBootApplication@EnableEurekaServerpublic class EurekaServerApplication {
public static void main(String[] args) { SpringApplication.run(EurekaServerApplication.class, args); }}
复制代码


  • 现在工程已经创建好了,可以开始构建了;

构建镜像

  • 在 pom.xml 所在目录执行以下命令即可构建镜像:


mvn clean package -U -DskipTests docker:dockerBuild
复制代码


  • 构建成功后,用 docker images 命令查看本地镜像列表如下,新增了 ID 为 90b736eb388e 的镜像:


[INFO] Built bolingcavalry/eureka-server[INFO] Tagging bolingcavalry/eureka-server with 0.0.1-SNAPSHOT[INFO] ------------------------------------------------------------------------[INFO] BUILD SUCCESS[INFO] ------------------------------------------------------------------------[INFO] Total time:  10.918 s[INFO] Finished at: 2019-06-01T08:36:59Z[INFO] ------------------------------------------------------------------------root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED             SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      90b736eb388e        5 seconds ago       683MBbolingcavalry/eureka-server   latest              90b736eb388e        5 seconds ago       683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago         643MB
复制代码


  • 再次执行命令 mvn clean package -U -DskipTests docker:build ,也就是再构建一次;

  • 构建完成后查看镜像列表,ID 为 90b736eb388e 的镜像已经成为 dangling images,标签 bolingcavalry/eureka-server:0.0.1-SNAPSHOT 已经被新镜像 be262f101e2c 占有:


[INFO] Built bolingcavalry/eureka-server[INFO] Tagging bolingcavalry/eureka-server with 0.0.1-SNAPSHOT[INFO] ------------------------------------------------------------------------[INFO] BUILD SUCCESS[INFO] ------------------------------------------------------------------------[INFO] Total time:  10.985 s[INFO] Finished at: 2019-06-01T08:44:49Z[INFO] ------------------------------------------------------------------------root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED              SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      be262f101e2c        About a minute ago   683MBbolingcavalry/eureka-server   latest              be262f101e2c        About a minute ago   683MB<none>                        <none>              90b736eb388e        9 minutes ago        683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago          643MB
复制代码


  • 此时,如果您的镜像列表出现<none>:<none> ,您也能分析出此现象的来源了,接下来试试如何清理 dangling images。

清理 dangling images

  • 如下所示,执行命令 docker image prune 即可删除 dangling images:


root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED              SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      be262f101e2c        About a minute ago   683MBbolingcavalry/eureka-server   latest              be262f101e2c        About a minute ago   683MB<none>                        <none>              90b736eb388e        9 minutes ago        683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago          643MBroot@hedy:/home/willzhao/temp/201906/01/eureka-server# docker image pruneWARNING! This will remove all dangling images.Are you sure you want to continue? [y/N] yDeleted Images:deleted: sha256:90b736eb388e42df2e4bc2ab3c8770a9a5f7563bb5af2493b88428c610f14f6bdeleted: sha256:db3657b5e27b7bf6c780e3280d6f2e24ffc26592a14b4efa651000130294b429deleted: sha256:afd10ec003e3132ea5e1c489ba5e51f53b0759351bdc175184ba82daaac178d1
Total reclaimed space: 39.94MB
复制代码


  • 再次查看,发现 90b736eb388e 已经不在列表中:


root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED             SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      be262f101e2c        39 minutes ago      683MBbolingcavalry/eureka-server   latest              be262f101e2c        39 minutes ago      683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago         643MB
复制代码

一点疑问

  • 再来看看官方对 dangling images 的解释,如下所示,有两个条件:没有标签、并且不再被容器使用:


  • 我的疑问:如果没有标签,但是正在被容器使用的镜像,应该不算 dangling images 吧,此时如果执行命令 docker image prune 会怎么样呢?

  • 我的猜测:docker image prune 是用来清理 dangling images 的,如果镜像正在被使用那就不算 dangling images,那就不会被清理掉;

  • 还是动手来试试吧:

  • 执行以下命令会用镜像 bolingcavalry/eureka-server:0.0.1-SNAPSHOT 创建一个容器:


docker run -idt bolingcavalry/eureka-server:0.0.1-SNAPSHOT
复制代码


  • 再次执行命令 mvn clean package -U -DskipTests docker:build ,也就是再构建一次;

  • 查看镜像信息如下,此时 be262f101e2c 在列表中已经显示成了<none>:<none>


root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED             SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      f83762738051        4 seconds ago       683MBbolingcavalry/eureka-server   latest              f83762738051        4 seconds ago       683MB<none>                        <none>              be262f101e2c        About an hour ago   683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago         643MB
复制代码


  • 执行命令 docker ps 查看容器,发现 IMAGE 字段已经变成了 ID(之前是 bolingcavalry/eureka-server:0.0.1-SNAPSHOT):


root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker psCONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMESf4e9b7aa6d25        be262f101e2c        "java -jar /eureka-s…"   7 minutes ago       Up 7 minutes                            gallant_bell
复制代码


  • 执行命令 docker image prune ,再查看镜像列表,如下,可见 be262f101e2c 依旧在列表中,没有被清理掉 ,符合之前的猜测:被容器用到的镜像不是 dangling images,用命令 docker image prune 无法清除:


root@hedy:/home/willzhao/temp/201906/01/eureka-server# docker image pruneWARNING! This will remove all dangling images.Are you sure you want to continue? [y/N] yTotal reclaimed space: 0Broot@hedy:/home/willzhao/temp/201906/01/eureka-server# docker imagesREPOSITORY                    TAG                 IMAGE ID            CREATED             SIZEbolingcavalry/eureka-server   0.0.1-SNAPSHOT      f83762738051        5 minutes ago       683MBbolingcavalry/eureka-server   latest              f83762738051        5 minutes ago       683MB<none>                        <none>              be262f101e2c        About an hour ago   683MBjava                          8u111-jdk           d23bdf5b1b1b        2 years ago         643MB
复制代码


  • 至此,对 Docker 镜像列表中的 none:none 已经了解,希望在您有类似疑惑时本文可以提供一些参考。

欢迎关注 InfoQ:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...


发布于: 3 小时前阅读数: 2
用户头像

搜索"程序员欣宸",一起畅游Java宇宙 2018.04.19 加入

前腾讯、前阿里员工,从事Java后台工作,对Docker和Kubernetes充满热爱,所有文章均为作者原创,个人Github:https://github.com/zq2599/blog_demos

评论

发布
暂无评论
Docker镜像列表中的none:none是什么_Docker_程序员欣宸_InfoQ写作社区