包装 OCI 图像
| 出于安全考虑,镜像以非root用户身份构建和运行。 更多细节请参见CNB规范。 |
最简单的入门方式是调用MVN Spring-boot:build-image在一个项目中。
只要包相位被调用,如下例所示:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>build-image-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
用构建-镜像-无分叉当目标绑定到包生命周期时。
这个目标类似于构建映像但不会分支生命周期以确保包已经跑了。
在本节其余部分,构建映像用来指代构建映像或构建-镜像-无分叉目标。 |
虽然构建包运行于可执行档案,但不必执行重新包装目标优先,因为如有需要,可执行档案会自动创建。
当构建映像重新打包应用程序,它应用的设置与重新包装目标是,也就是说,依赖关系可以通过排除选项之一被排除。
这Spring-boot-devtools和Spring-boot-docker-compose模块默认会自动排除(你可以用exclusionDevtools和exclusionDockerCompose性质)。 |
Docker 守护进程
这构建映像目标需要访问 Docker 守护进程。
目标是检查本地 Docker CLI 配置文件以确定当前上下文,并利用上下文连接信息与 Docker 守护进程通信。
如果无法确定当前上下文或上下文没有连接信息,则目标将使用默认的本地连接。
这在所有支持的平台上的 Docker Engine 无需配置即可运行。
环境变量可以设置为配置构建映像目标是使用替代的本地或远程连接。
下表展示了环境变量及其值:
| 环境变量 | 描述 |
|---|---|
DOCKER_CONFIG |
用于确定当前上下文的Docker CLI配置文件位置(默认为 |
DOCKER_CONTEXT |
应用于从 Docker CLI 配置文件中获取主机信息的上下文名称(覆盖 |
DOCKER_HOST |
包含 Docker 守护进程主机和端口的 URL - 例如。 |
DOCKER_TLS_VERIFY |
当设置为 时启用安全HTTPS协议 |
DOCKER_CERT_PATH |
HTTPS的证书和密钥文件路径(如果需要 |
Docker 守护进程连接信息也可以通过以下方式提供Jetty工人插件配置中的参数。
下表总结了可用参数:
| 参数 | 描述 |
|---|---|
|
|
|
包含 Docker 守护进程主机和端口的 URL - 例如。 |
|
当设置为 时启用安全HTTPS协议 |
|
HTTPS的证书和密钥文件路径(如果需要 |
|
什么时候 |
更多细节,请参见示例。
Docker 注册表
如果 Docker 镜像由架构工人或runImage参数存储在需要认证的私有 Docker 映像注册表中,认证凭证可以通过以下方式提供docker.builderRegistry参数。
如果生成的 Docker 镜像要发布到 Docker 镜像注册表,认证凭证可以通过以下方式提供docker.publishRegistry参数。
为用户认证或身份Tokens认证提供了参数。 请参阅用于存储镜像的 Docker 注册表文档,了解更多支持的认证方法信息。
下表总结了可用参数docker.builderRegistry和docker.publishRegistry:
| 参数 | 描述 |
|---|---|
|
Docker 映像注册用户的用户名。用户认证必修。 |
|
Docker 映像注册表用户的密码。用户认证必修。 |
|
Docker 镜像注册表的地址。用户认证时可选。 |
|
Docker 映像注册表用户的电子邮件地址。用户认证时可选。 |
|
为 Docker 映像注册表用户提供身份Tokens。Tokens认证必不可少。 |
更多细节,请参见示例。
|
如果未提供凭证,插件会读取用户现有的 Docker 配置文件(通常位于 该插件支持以下认证方法:
|
图像定制
这图像参数允许构建者配置及其在项目中的作方式。
下表总结了可用参数及其默认值:
| 参数 / (用户属性) | 描述 | 默认值 |
|---|---|---|
|
使用建造器镜像的名称。 |
|
|
是否应该把建造商当作值得信赖的人。 |
|
|
任何被拉取的构建器、运行和构建包镜像的平台(作系统和架构)。
必须以 的形式出现 |
没有默认值,表示应使用主机平台。 |
|
使用运行图像的名称。 |
不应使用构建器元数据中指定的运行镜像的默认值。 |
|
生成图像的图像名称。 |
|
|
用来决定何时拉取构建器并从注册表运行映像的策略。
可接受的值为 |
|
|
应该传递给构建者的环境变量。 |
|
|
构建者在构建镜像时应该使用的构建包。 只会使用指定的构建包,覆盖构建者中包含的默认构建包。 构建包引用必须以以下形式之一进行:
|
没有,说明建造者应该使用其中的构建包。 |
|
卷绑定挂载应该挂载到构建器容器上,这样可以构建映像。 在创建构建容器时,绑定会未解析且未验证地传递给 Docker。 装订必须采用以下形式之一:
哪里
|
|
|
构建容器将被配置为使用的网络驱动。 在创建构建容器时,提供的值会在未验证的情况下传递给 Docker。 |
|
|
是否在建造前清理缓存。 |
|
|
支持对架构商作的详细记录。 |
|
|
是否将生成的镜像发布到Docker注册表。 |
|
|
添加一个或多个额外标签以应用到生成的图像上。
提供给 |
|
|
一个临时工作区,供构建器和构建包在构建映像时存储文件。 该值可以是命名卷或绑定挂载位置。 |
Docker 守护进程中的一个命名卷,名称源自镜像名。 |
|
一个包含由构建包创建并用于图像构建过程的图层的缓存。 该值可以是命名卷或绑定挂载位置。 |
Docker 守护进程中的一个命名卷,名称源自镜像名。 |
|
一个包含由构建包创建并用于镜像启动过程的层的缓存。 该值可以是命名卷或绑定挂载位置。 |
Docker 守护进程中的一个命名卷,名称源自镜像名。 |
|
一个将用来设定 |
一个固定日期,以便构建可重复。 |
|
构建器镜像中应用内容将上传到的目录路径。 应用内容也会出现在生成图像的这个位置。 |
|
|
安全选项将应用到构建器容器,以字符串数组形式提供 |
|
插件通过编译器的插件配置或maven.compiler.target财产。
使用默认的 Paketo 构建器和构建包时,插件会指示构建包安装相同的 Java 版本。
你可以像构建器配置示例中所示覆盖这个行为。 |
更多细节,请参见示例。
Spring Boot:构建映像
org.springframework.boot:spring-boot-maven-plugin:4.0.0
用构建包将应用打包打包成 OCI 镜像,分叉生命周期以确保包跑。 该目标适用于命令行调用。如果你需要配置目标执行在你的构建中,使用构建-镜像-无分叉相反。
可选参数
| 名称 | 类型 | 默认值 |
|---|---|---|
|
||
|
||
|
||
|
||
|
|
|
|
|
|
|
||
|
||
|
||
|
||
|
||
|
|
|
|
|
|
|
|
|
|
||
|
||
|
||
|
||
|
||
|
|
|
|
参数细节
applicationDirectory
别名图片#applicationDirectory通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
cleanCache
别名图片#清洁缓存通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
创建日期
别名图片#创建日期通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionDevtools
从重新打包的压缩包中排除 Spring Boot 开发工具。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionDockerCompose
从重新打包的压缩包中排除 Spring Boot 开发服务。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionGroupIds
逗号分隔的groupid名称列表,排除(完全匹配)。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
排除
排除的工件定义集合。这排除元素定义了强制性组ID和artifactId(遗物ID组件和可选分类元件。当配置为属性时,值应以逗号分隔,并用冒号分隔:groupId:artifactId,groupId:artifactId:分类器
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imageBuilder
别名图片#构建者通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imageName
别名图片#name通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imagePlatform
别名图片#image平台通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
包括
包含工件定义的集合。这包括元素定义了强制性组ID和artifactId(遗物ID组件和可选分类元件。当配置为属性时,值应以逗号分隔,并用冒号分隔:groupId:artifactId,groupId:artifactId:分类器
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
布局
归档类型(对应于其内部依赖的布局)。可能的值有罐,战争,ZIP,迪尔,没有.默认根据档案类型进行猜测。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
pullPolicy
别名图片#pullPolicy通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
runImage
别名图片#运行图片通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
spring-boot:build-image-no-fork
org.springframework.boot:spring-boot-maven-plugin:4.0.0
将应用打包成 OCI 镜像,使用构建包,但不分叉生命周期。该目标应在配置目标时使用执行在你的构建中。要在命令行调用目标,请使用构建映像相反。
可选参数
| 名称 | 类型 | 默认值 |
|---|---|---|
|
||
|
||
|
||
|
||
|
|
|
|
|
|
|
||
|
||
|
||
|
||
|
||
|
|
|
|
|
|
|
|
|
|
||
|
||
|
||
|
||
|
||
|
|
|
|
参数细节
applicationDirectory
别名图片#applicationDirectory通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
cleanCache
别名图片#清洁缓存通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
创建日期
别名图片#创建日期通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionDevtools
从重新打包的压缩包中排除 Spring Boot 开发工具。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionDockerCompose
从重新打包的压缩包中排除 Spring Boot 开发服务。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
exclusionGroupIds
逗号分隔的groupid名称列表,排除(完全匹配)。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
排除
排除的工件定义集合。这排除元素定义了强制性组ID和artifactId(遗物ID组件和可选分类元件。当配置为属性时,值应以逗号分隔,并用冒号分隔:groupId:artifactId,groupId:artifactId:分类器
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imageBuilder
别名图片#构建者通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imageName
别名图片#name通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
imagePlatform
别名图片#image平台通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
包括
包含工件定义的集合。这包括元素定义了强制性组ID和artifactId(遗物ID组件和可选分类元件。当配置为属性时,值应以逗号分隔,并用冒号分隔:groupId:artifactId,groupId:artifactId:分类器
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
布局
归档类型(对应于其内部依赖的布局)。可能的值有罐,战争,ZIP,迪尔,没有.默认根据档案类型进行猜测。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
pullPolicy
别名图片#pullPolicy通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
runImage
别名图片#运行图片通过命令行属性支持配置。
名称 |
|
|---|---|
类型 |
|
默认值 |
|
用户属性 |
|
因为 |
|
例子
自定义图像构建器
如果你需要自定义用于创建镜像的构建器或用于启动构建镜像的运行镜像,请按照以下示例配置插件:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<builder>mine/java-cnb-builder</builder>
<runImage>mine/java-cnb-run</runImage>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
该配置将使用带有名称的构建器镜像矿山/Java-CNB-构建器以及标签最近的,以及名为mine/java-cnb-run以及标签最近的.
构建器和运行镜像也可以在命令行中指定,如本例所示:
$ mvn spring-boot:build-image -Dspring-boot.build-image.builder=mine/java-cnb-builder -Dspring-boot.build-image.runImage=mine/java-cnb-run
建造者配置
如果构建者通过环境变量暴露配置选项,这些变量可以通过环境属性。
以下是 Paketo Java 构建包在构建时配置 JVM 版本的示例:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<env>
<BP_JVM_VERSION>17</BP_JVM_VERSION>
</env>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
如果构建器运行的 Docker 守护进程和构建包下载工件的网络位置之间存在网络代理,你需要配置建构者使用该代理。
使用Paketo构建器时,可以通过设置HTTPS_PROXY和/或HTTP_PROXY环境变量如下例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<env>
<HTTP_PROXY>http://proxy.example.com</HTTP_PROXY>
<HTTPS_PROXY>https://proxy.example.com</HTTPS_PROXY>
</env>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
运行时JVM 配置
应存储在镜像中并应用于每次部署的环境变量修改,可以按照Paketo文档中的描述设置,并展示如下示例:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<env>
<BPE_DELIM_JAVA_TOOL_OPTIONS xml:space="preserve"> </BPE_DELIM_JAVA_TOOL_OPTIONS>
<BPE_APPEND_JAVA_TOOL_OPTIONS>-XX:+HeapDumpOnOutOfMemoryError</BPE_APPEND_JAVA_TOOL_OPTIONS>
</env>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
自定义图片名称
默认情况下,图像名称是从以下artifactId(遗物ID以及版本项目中,类似这样的docker.io/library/${project.artifactId}:${project.version}.
你可以控制名称,如下示例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<name>example.com/library/${project.artifactId}</name>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
该配置不提供显式标签,因此最近的被使用。
也可以指定标签,比如${project.version},构建中可用的任何属性或硬编码版本。 |
图像名称也可以在命令行中指定,如示例所示:
$ mvn spring-boot:build-image -Dspring-boot.build-image.imageName=example.com/library/my-app:v1
构建包
默认情况下,构建器会使用构建器镜像中包含的构建包,并按预定义顺序应用。 还可以提供一套替代的构建包,用于应用未包含在构建包中的构建包,或改变包含构建包的顺序。 当提供一个或多个构建包时,只有指定的构建包会被应用。
以下示例指示构建者使用一个自定义构建包,封装在.tgz文件,接着是构建器中包含的构建包。
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<buildpacks>
<buildpack>file:///path/to/example-buildpack.tgz</buildpack>
<buildpack>urn:cnb:builder:paketo-buildpacks/java</buildpack>
</buildpacks>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
构建包可以通过以下任何形式来指定。
位于CNB构建器中的构建包(如果构建器中只有一个构建包与buildpack-id):
-
urn:cnb:builder:buildpack-id -
urn:cnb:builder:[email protected] -
buildpack-id
一个指向包含构建包内容目录的路径(Windows不支持):
-
file:///path/to/buildpack/ -
/path/to/buildpack/
一个指向包含构建包内容的 gzip tar 文件的路径:
-
file:///path/to/buildpack.tgz -
/path/to/buildpack.tgz
包含一个包含打包构建包的 OCI 镜像:
-
docker://example/buildpack -
docker:///example/buildpack:latest -
docker:///example/buildpack@sha256:45b23dee08...... -
示例/构建包 -
example/buildpack:latest -
example/buildpack@sha256:45b23dee08...
Image 出版
生成的镜像可以通过启用发布选择。
如果 Docker 注册表需要认证,凭证可以通过以下方式配置docker.publishRegistry参数。
如果 Docker 注册表不需要认证,那么docker.publishRegistry配置可以省略。
图像将被发布到的注册表由图像名称中的注册表部分决定(docker.example.com在这些例子中)。
如果docker.publishRegistry凭据配置包括网址参数,该值传递给注册表,但不用于确定发布注册表的位置。 |
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<name>docker.example.com/library/${project.artifactId}</name>
<publish>true</publish>
</image>
<docker>
<publishRegistry>
<username>user</username>
<password>secret</password>
</publishRegistry>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
这发布选项也可以在命令行中指定,如本示例所示:
$ mvn spring-boot:build-image -Dspring-boot.build-image.imageName=docker.example.com/library/my-app:v1 -Dspring-boot.build-image.publish=true
当使用发布在命令行中选择认证时,你可以像这个例子中那样,使用属性来提供凭证:
$ mvn spring-boot:build-image \
-Ddocker.publishRegistry.username=user \
-Ddocker.publishRegistry.password=secret \
-Ddocker.publishRegistry.url=docker.example.com \
-Dspring-boot.build-image.publish=true \
-Dspring-boot.build-image.imageName=docker.example.com/library/my-app:v1
并在XML配置中引用属性:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<publishRegistry>
<url>${docker.publishRegistry.url}</url>
<username>${docker.publishRegistry.username}</username>
<password>${docker.publishRegistry.password}</password>
</publishRegistry>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
构建缓存与工作区配置
CNB 构建器缓存用于构建和启动图像时使用的图层。 默认情况下,这些缓存以命名卷的形式存储在 Docker 守护进程中,这些卷的名称源自目标镜像的全名。 如果图片名称频繁更改,例如当项目版本作为图片名称中的标签时,缓存可能会频繁失效。
缓存卷可以配置为使用替代名称,以便更好地控制缓存生命周期,如下示例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<buildCache>
<volume>
<name>cache-${project.artifactId}.build</name>
</volume>
</buildCache>
<launchCache>
<volume>
<name>cache-${project.artifactId}.launch</name>
</volume>
</launchCache>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
构建器和构建包需要一个位置来存储图像构建过程中的临时文件。 默认情况下,这个临时构建工作区存储在一个命名卷中。
缓存和构建工作区可以配置为使用绑定挂载而非命名卷,如下示例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<image>
<buildWorkspace>
<bind>
<source>/tmp/cache-${project.artifactId}.work</source>
</bind>
</buildWorkspace>
<buildCache>
<bind>
<source>/tmp/cache-${project.artifactId}.build</source>
</bind>
</buildCache>
<launchCache>
<bind>
<source>/tmp/cache-${project.artifactId}.launch</source>
</bind>
</launchCache>
</image>
</configuration>
</plugin>
</plugins>
</build>
</project>
Docker 配置
Docker Configuration for minikube
该插件可以与 minikube 提供的 Docker 守护进程通信,而非默认的本地连接。
在 Linux 和 macOS 上,环境变量可以通过以下命令设置Eval $(minikube Docker-env)在迷你久部启动之后。
插件还可以通过提供类似下例所示的连接细节来配置使用 minikube 守护进程:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<host>tcp://192.168.99.100:2376</host>
<tlsVerify>true</tlsVerify>
<certPath>/home/user/.minikube/certs</certPath>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
Docker Configuration for podman
该插件可以与 podman 容器引擎通信。
该插件可以通过提供类似于下例所示的连接细节来配置为使用 Podman 本地连接:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<host>unix:///run/user/1000/podman/podman.sock</host>
<bindHostToBuilder>true</bindHostToBuilder>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
与科利马CLI安装了命令舱员信息 --format='{{.Host.RemoteSocket.Path}}'可以用来获得docker.host本例所示的配置性质。 |
Colima 的 Docker 配置
该插件可以与 Colima 提供的 Docker 守护进程通信。
这DOCKER_HOST环境变量可以通过以下命令设置:
$ export DOCKER_HOST=$(docker context inspect colima -f '{{.Endpoints.docker.Host}}')
插件还可以通过提供类似下例所示的连接细节来配置使用 Colima 守护进程:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<host>unix:///${user.home}/.colima/docker.sock</host>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
身份验证用的 Docker 配置
如果构建器或运行镜像存储在支持用户认证的私有 Docker 注册表中,可以通过以下方式提供认证细节docker.builderRegistry参数如下例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<builderRegistry>
<username>user</username>
<password>secret</password>
<url>https://docker.example.com/v1/</url>
<email>[email protected]</email>
</builderRegistry>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>
如果构建器或运行镜像存储在支持Tokens认证的私有 Docker 注册表中,则可以通过以下方式提供Tokens值docker.builderRegistry参数如下例所示:
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<docker>
<builderRegistry>
<token>9cbaf023786cd7...</token>
</builderRegistry>
</docker>
</configuration>
</plugin>
</plugins>
</build>
</project>