背景
在咱们开发过程中为了反对 Docker 容器化,个别应用 Maven 编译打包而后生成镜像,可能大大提供上线效率,同时可能疾速动静扩容,疾速回滚,着实很不便。docker-maven-plugin 插件就是为了帮忙咱们在 Maven 工程中,通过简略的配置,主动生成镜像并推送到仓库中。
spotify、fabric8
- 这里次要应用的次要是如下两种插件
spotify
、fabric8
, … - 配置通过 xml 定义出 Dockerfile 或者挂载内部 Dockerfile 通过调用 Docker remote api 构建出镜像 - pig 微服务平台所有的容器化都是基于此构建
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
... - 配置通过 xml 定义出 Dockerfile 或者挂载内部 Dockerfile
</plugin>
<plugin>
<groupId>io.fabric8</groupId>
<artifactId>docker-maven-plugin</artifactId>
... - 配置通过 xml 定义出 Dockerfile 或者挂载内部 Dockerfile
</plugin>
- 执行相应的插件周期即可
mvn docker:build && mvn docker:push
jib
- 我的项目每次公布实际上变更的代码量不大,尤其依赖的 jar 变动的可能性较小,如果应用前两种插件构建镜像,会导致每次都全量构建,会导致存储和带宽资源节约。
- jib 是 Google 于 18 年 7 月公布的一个针对 Java 利用的构建镜像的工具 (反对 Maven 和 Gradle),益处是可能复用构建缓存,可能放慢构建,减小传输体积
<!-- 配置通过 xml 定义出 Dockerfile,实质上和外挂 Dockerfile 并无区别 -->
<plugin>
<groupId>com.google.cloud.tools</groupId>
<artifactId>jib-maven-plugin</artifactId>
</plugin>
mvn jib:dockerBuild
以上三种计划的问题
- 在理论开发过程中,大部分的 spring boot 我的项目构建 Dockerfile 都是雷同,不须要通过的 XML 或者通过外挂 Dockerfile 来从新定义
- 以上插件须要对 Dockerfile 的定义常识有绝对的了 对开发并不敌对
- 没充沛理由 Spring Boot 2.3 当前的 Jar 分层技术。
解决方案
- Spring Boot 2.4 推出了本人的 docker 构建工具 整合在原有的
spring-boot-maven-plugin
中,只须要配置对应指标仓库和主机信息即可实现镜像构建。
- 如下配置即可实现上图中 通过开发机器在不装置 Docker 的同时,通过
192.168.0.10
的 Docker Remote API 实现镜像构建并公布到192.168.0.20
的镜像仓库
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<name>192.168.0.20/pig4cloud/${project.artifactId}</name>
<!-- 执行完 build 主动 push -->
<publish>true</publish>
</image>
<!-- 配置构建宿主机信息,本机不必配置 -->
<docker>
<host>http://192.168.0.10:2375</host>
<tlsVerify>false</tlsVerify>
<publishRegistry>
<username>username</username>
<password>password</password>
<url>192.168.0.20</url>
</publishRegistry>
</docker>
</configuration>
</plugin>
- 执行以下命令即可实现 镜像的构建和主动公布
mvn spring-boot:build-image
其余阐明
docker host 配置不失效
- 如下图 ① 处配置 <host></host> 节点,然而 ② 报错提醒 host 不统一
- 查看本地是否配置 \$DOCKER_HOST 环境变量,通过浏览源码后发现优先读取此变量。
⋊> ~ echo $DOCKER_HOST 11:07:51
tcp://172.17.0.111:2375
网络反对
- 截取局部构建过程中的日志,如下须要从 github 下载相干的依赖 约 100M,这个过程大概率会失败。倡议通过配置代理或者应用国外 ECS 来解决。
:: Spring Boot :: (v2.4.0)
[INFO] > Running creator
[INFO] [creator] Downloading from https://github.com/bell-sw/Liberica/releases/download/8u275+1/bellsoft-jre8u275+1-linux-amd64.tar.gz
[INFO] [creator] JVMKill Agent 1.16.0: Contributing to layer
[INFO] [creator] Downloading from https://github.com/cloudfoundry/jvmkill/releases/download/v1.16.0.RELEASE/jvmkill-1.16.0-RELEASE.so
[INFO] [creator] Downloading from https://repo.spring.io/release/org/springframework/cloud/spring-cloud-bindings/1.6.0/spring-cloud-bindings-1.6.0.jar
[INFO] [creator] Verifying checksum
[INFO] [creator] 192.168.0.20/pig4cloud/demo:latest
[INFO]
[INFO] Successfully built image '192.168.0.20/pig4cloud/demo:latest'
[INFO] > Pushing image '192.168.0.20/pig4cloud/demo:latest' 100%
[INFO] > Pushed image '192.168.0.20/pig4cloud/demo:latest'
[INFO] BUILD SUCCESS