| This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Boot 3.5.6! | 
Packaging OCI Images
The plugin can create an OCI image from a jar or war file using Cloud Native Buildpacks (CNB).
Images can be built on the command-line using the build-image goal.
This makes sure that the package lifecycle has run before the image is created.
| For security reasons, images build and run as non-root users. See the CNB specification for more details. | 
The easiest way to get started is to invoke mvn spring-boot:build-image on a project.
It is possible to automate the creation of an image whenever the package phase is invoked, as shown in the following example:
<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>| Use build-image-no-forkwhen binding the goal to the package lifecycle.
This goal is similar tobuild-imagebut does not fork the lifecycle to make surepackagehas run.
In the rest of this section,build-imageis used to refer to either thebuild-imageorbuild-image-no-forkgoals. | 
| While the buildpack runs from an executable archive, it is not necessary to execute the repackagegoal first as the executable archive is created automatically if necessary.
When thebuild-imagerepackages the application, it applies the same settings as therepackagegoal would, that is dependencies can be excluded using one of the exclude options.
Thespring-boot-devtoolsandspring-boot-docker-composemodules are automatically excluded by default (you can control this using theexcludeDevtoolsandexcludeDockerComposeproperties). | 
Docker Daemon
The build-image goal requires access to a Docker daemon.
The goal will inspect local Docker CLI configuration files to determine the current context and use the context connection information to communicate with a Docker daemon.
If the current context can not be determined or the context does not have connection information, then the goal will use a default local connection.
This works with Docker Engine on all supported platforms without configuration.
Environment variables can be set to configure the build-image goal to use an alternative local or remote connection.
The following table shows the environment variables and their values:
| Environment variable | Description | 
|---|---|
| DOCKER_CONFIG | Location of Docker CLI configuration files used to determine the current context (defaults to  | 
| DOCKER_CONTEXT | Name of a context that should be used to retrieve host information from Docker CLI configuration files (overrides  | 
| DOCKER_HOST | URL containing the host and port for the Docker daemon - for example  | 
| DOCKER_TLS_VERIFY | Enable secure HTTPS protocol when set to  | 
| DOCKER_CERT_PATH | Path to certificate and key files for HTTPS (required if  | 
Docker daemon connection information can also be provided using docker parameters in the plugin configuration.
The following table summarizes the available parameters:
| Parameter | Description | 
|---|---|
| 
 | Name of a context that should be used to retrieve host information from Docker CLI configuration files | 
| 
 | URL containing the host and port for the Docker daemon - for example  | 
| 
 | Enable secure HTTPS protocol when set to  | 
| 
 | Path to certificate and key files for HTTPS (required if  | 
| 
 | When  | 
For more details, see also examples.
Docker Registry
If the Docker images specified by the builder or runImage parameters are stored in a private Docker image registry that requires authentication, the authentication credentials can be provided using docker.builderRegistry parameters.
If the generated Docker image is to be published to a Docker image registry, the authentication credentials can be provided using docker.publishRegistry parameters.
Parameters are provided for user authentication or identity token authentication. Consult the documentation for the Docker registry being used to store images for further information on supported authentication methods.
The following table summarizes the available parameters for docker.builderRegistry and docker.publishRegistry:
| Parameter | Description | 
|---|---|
| 
 | Username for the Docker image registry user. Required for user authentication. | 
| 
 | Password for the Docker image registry user. Required for user authentication. | 
| 
 | Address of the Docker image registry. Optional for user authentication. | 
| 
 | E-mail address for the Docker image registry user. Optional for user authentication. | 
| 
 | Identity token for the Docker image registry user. Required for token authentication. | 
For more details, see also examples.
| If credentials are not provided, the plugin reads the user’s existing Docker configuration file (typically located at  The plugin supports the following authentication methods: 
 | 
Image Customizations
The plugin invokes a builder to orchestrate the generation of an image. The builder includes multiple buildpacks that can inspect the application to influence the generated image. By default, the plugin chooses a builder image. The name of the generated image is deduced from project properties.
The image parameter allows configuration of the builder and how it should operate on the project.
The following table summarizes the available parameters and their default values:
| Parameter / (User Property) | Description | Default value | 
|---|---|---|
| 
 | Name of the builder image to use. | 
 | 
| 
 | Whether to treat the builder as trusted. | 
 | 
| 
 | The platform (operating system and architecture) of any builder, run, and buildpack images that are pulled.
Must be in the form of  | No default value, indicating that the platform of the host machine should be used. | 
| 
 | Name of the run image to use. | No default value, indicating the run image specified in Builder metadata should be used. | 
| 
 | Image name for the generated image. | 
 | 
| 
 | Policy used to determine when to pull the builder and run images from the registry.
Acceptable values are  | 
 | 
| 
 | Environment variables that should be passed to the builder. | |
| 
 | Buildpacks that the builder should use when building the image. Only the specified buildpacks will be used, overriding the default buildpacks included in the builder. Buildpack references must be in one of the following forms: 
 | None, indicating the builder should use the buildpacks included in it. | 
| 
 | Volume bind mounts that should be mounted to the builder container when building the image. The bindings will be passed unparsed and unvalidated to Docker when creating the builder container. Bindings must be in one of the following forms: 
 Where  
 | |
| 
 | The network driver the builder container will be configured to use. The value supplied will be passed unvalidated to Docker when creating the builder container. | |
| 
 | Whether to clean the cache before building. | 
 | 
| 
 | Enables verbose logging of builder operations. | 
 | 
| 
 | Whether to publish the generated image to a Docker registry. | 
 | 
| 
 | One or more additional tags to apply to the generated image.
The values provided to the  | |
| 
 | A temporary workspace that will be used by the builder and buildpacks to store files during image building. The value can be a named volume or a bind mount location. | A named volume in the Docker daemon, with a name derived from the image name. | 
| 
 | A cache containing layers created by buildpacks and used by the image building process. The value can be a named volume or a bind mount location. | A named volume in the Docker daemon, with a name derived from the image name. | 
| 
 | A cache containing layers created by buildpacks and used by the image launching process. The value can be a named volume or a bind mount location. | A named volume in the Docker daemon, with a name derived from the image name. | 
| 
 | A date that will be used to set the  | A fixed date that enables build reproducibility. | 
| 
 | The path to a directory that application contents will be uploaded to in the builder image. Application contents will also be in this location in the generated image. | 
 | 
| 
 | Security options that will be applied to the builder container, provided as an array of string values | 
 | 
| The plugin detects the target Java compatibility of the project using the compiler’s plugin configuration or the maven.compiler.targetproperty.
When using the default Paketo builder and buildpacks, the plugin instructs the buildpacks to install the same Java version.
You can override this behaviour as shown in the builder configuration examples. | 
For more details, see also examples.
Tags Format
The values provided to the tags option should be full image references.
The accepted format is [domainHost:port/][path/]name[:tag][@digest].
If the domain is missing, it defaults to docker.io.
If the path is missing, it defaults to library.
If the tag is missing, it defaults to latest.
Some examples:
- 
my-imageleads to the image referencedocker.io/library/my-image:latest
- 
my-repository/my-imageleads todocker.io/my-repository/my-image:latest
- 
example.com/my-repository/my-image:1.0.0will be used as is
spring-boot:build-image
org.springframework.boot:spring-boot-maven-plugin:4.0.0-SNAPSHOT
Package an application into an OCI image using a buildpack, forking the lifecycle to make sure that package ran. This goal is suitable for command-line invocation. If you need to configure a goal execution in your build, use build-image-no-fork instead.
Optional parameters
| Name | Type | Default | 
|---|---|---|
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
 | |
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
 | |
| 
 | 
 | |
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
Parameter details
applicationDirectory
Alias for Image#applicationDirectory to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
classifier
Classifier used when finding the source archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
cleanCache
Alias for Image#cleanCache to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
createdDate
Alias for Image#createdDate to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
excludeDevtools
Exclude Spring Boot devtools from the repackaged archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
excludeDockerCompose
Exclude Spring Boot dev services from the repackaged archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
excludeGroupIds
Comma separated list of groupId names to exclude (exact match).
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
excludes
Collection of artifact definitions to exclude. The Exclude element defines mandatory groupId and artifactId components and an optional classifier component. When configured as a property, values should be comma-separated with colon-separated components: groupId:artifactId,groupId:artifactId:classifier
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
image
Image configuration, with builder, runImage, name, env, cleanCache, verboseLogging, pullPolicy, and publish options.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
imageBuilder
Alias for Image#builder to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
imageName
Alias for Image#name to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
imagePlatform
Alias for Image#imagePlatform to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
includeOptional
Include optional dependencies.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includeSystemScope
Include system scoped dependencies.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includeTools
Include JAR tools.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includes
Collection of artifact definitions to include. The Include element defines mandatory groupId and artifactId components and an optional classifier component. When configured as a property, values should be comma-separated with colon-separated components: groupId:artifactId,groupId:artifactId:classifier
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
layers
Layer configuration with options to disable layer creation, exclude layer tools jar, and provide a custom layers configuration file.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
layout
The type of archive (which corresponds to how the dependencies are laid out inside it). Possible values are JAR, WAR, ZIP, DIR, NONE. Defaults to a guess based on the archive type.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
layoutFactory
The layout factory that will be used to create the executable archive if no explicit layout is set. Alternative layouts implementations can be provided by 3rd parties.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
mainClass
The name of the main class. If not specified the first compiled class found that contains a main method will be used.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
network
Alias for Image#network to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
publish
Alias for Image#publish to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
pullPolicy
Alias for Image#pullPolicy to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
runImage
Alias for Image#runImage to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
skip
Skip the execution.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
spring-boot:build-image-no-fork
org.springframework.boot:spring-boot-maven-plugin:4.0.0-SNAPSHOT
Package an application into an OCI image using a buildpack, but without forking the lifecycle. This goal should be used when configuring a goal execution in your build. To invoke the goal on the command-line, use build-image instead.
Optional parameters
| Name | Type | Default | 
|---|---|---|
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
 | |
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
 | |
| 
 | 
 | |
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | 
 | |
| 
 | 
Parameter details
applicationDirectory
Alias for Image#applicationDirectory to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
classifier
Classifier used when finding the source archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
cleanCache
Alias for Image#cleanCache to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
createdDate
Alias for Image#createdDate to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
excludeDevtools
Exclude Spring Boot devtools from the repackaged archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
excludeDockerCompose
Exclude Spring Boot dev services from the repackaged archive.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
excludeGroupIds
Comma separated list of groupId names to exclude (exact match).
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
excludes
Collection of artifact definitions to exclude. The Exclude element defines mandatory groupId and artifactId components and an optional classifier component. When configured as a property, values should be comma-separated with colon-separated components: groupId:artifactId,groupId:artifactId:classifier
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
image
Image configuration, with builder, runImage, name, env, cleanCache, verboseLogging, pullPolicy, and publish options.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
imageBuilder
Alias for Image#builder to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
imageName
Alias for Image#name to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
imagePlatform
Alias for Image#imagePlatform to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
includeOptional
Include optional dependencies.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includeSystemScope
Include system scoped dependencies.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includeTools
Include JAR tools.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | |
| Since | 
 | 
includes
Collection of artifact definitions to include. The Include element defines mandatory groupId and artifactId components and an optional classifier component. When configured as a property, values should be comma-separated with colon-separated components: groupId:artifactId,groupId:artifactId:classifier
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
layers
Layer configuration with options to disable layer creation, exclude layer tools jar, and provide a custom layers configuration file.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
layout
The type of archive (which corresponds to how the dependencies are laid out inside it). Possible values are JAR, WAR, ZIP, DIR, NONE. Defaults to a guess based on the archive type.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
layoutFactory
The layout factory that will be used to create the executable archive if no explicit layout is set. Alternative layouts implementations can be provided by 3rd parties.
| Name | 
 | 
|---|---|
| Type | |
| Default value | |
| User property | |
| Since | 
 | 
mainClass
The name of the main class. If not specified the first compiled class found that contains a main method will be used.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | |
| Since | 
 | 
network
Alias for Image#network to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
publish
Alias for Image#publish to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
pullPolicy
Alias for Image#pullPolicy to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
runImage
Alias for Image#runImage to support configuration through command-line property.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | |
| User property | 
 | 
| Since | 
 | 
skip
Skip the execution.
| Name | 
 | 
|---|---|
| Type | 
 | 
| Default value | 
 | 
| User property | 
 | 
| Since | 
 | 
Examples
Custom Image Builder
If you need to customize the builder used to create the image or the run image used to launch the built image, configure the plugin as shown in the following example:
<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>This configuration will use a builder image with the name mine/java-cnb-builder and the tag latest, and the run image named mine/java-cnb-run and the tag latest.
The builder and run image can be specified on the command line as well, as shown in this example:
$ mvn spring-boot:build-image -Dspring-boot.build-image.builder=mine/java-cnb-builder -Dspring-boot.build-image.runImage=mine/java-cnb-runBuilder Configuration
If the builder exposes configuration options using environment variables, those can be set using the env attributes.
The following is an example of configuring the JVM version used by the Paketo Java buildpacks at build time:
<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>If there is a network proxy between the Docker daemon the builder runs in and network locations that buildpacks download artifacts from, you will need to configure the builder to use the proxy.
When using the Paketo builder, this can be accomplished by setting the HTTPS_PROXY and/or HTTP_PROXY environment variables as show in the following example:
<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>Runtime JVM Configuration
Paketo Java buildpacks configure the JVM runtime environment by setting the JAVA_TOOL_OPTIONS environment variable.
The buildpack-provided JAVA_TOOL_OPTIONS value can be modified to customize JVM runtime behavior when the application image is launched in a container.
Environment variable modifications that should be stored in the image and applied to every deployment can be set as described in the Paketo documentation and shown in the following example:
<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>Custom Image Name
By default, the image name is inferred from the artifactId and the version of the project, something like docker.io/library/${project.artifactId}:${project.version}.
You can take control over the name, as shown in the following example:
<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>| This configuration does not provide an explicit tag so latestis used.
It is possible to specify a tag as well, either using${project.version}, any property available in the build or a hardcoded version. | 
The image name can be specified on the command line as well, as shown in this example:
$ mvn spring-boot:build-image -Dspring-boot.build-image.imageName=example.com/library/my-app:v1Buildpacks
By default, the builder will use buildpacks included in the builder image and apply them in a pre-defined order. An alternative set of buildpacks can be provided to apply buildpacks that are not included in the builder, or to change the order of included buildpacks. When one or more buildpacks are provided, only the specified buildpacks will be applied.
The following example instructs the builder to use a custom buildpack packaged in a .tgz file, followed by a buildpack included in the builder.
<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>Buildpacks can be specified in any of the forms shown below.
A buildpack located in a CNB Builder (version may be omitted if there is only one buildpack in the builder matching the buildpack-id):
- 
urn:cnb:builder:buildpack-id
- 
urn:cnb:builder:[email protected]
- 
buildpack-id
A path to a directory containing buildpack content (not supported on Windows):
- 
file:///path/to/buildpack/
- 
/path/to/buildpack/
A path to a gzipped tar file containing buildpack content:
- 
file:///path/to/buildpack.tgz
- 
/path/to/buildpack.tgz
An OCI image containing a packaged buildpack:
- 
docker://example/buildpack
- 
docker:///example/buildpack:latest
- 
docker:///example/buildpack@sha256:45b23dee08…
- 
example/buildpack
- 
example/buildpack:latest
- 
example/buildpack@sha256:45b23dee08…
Image Publishing
The generated image can be published to a Docker registry by enabling a publish option.
If the Docker registry requires authentication, the credentials can be configured using docker.publishRegistry parameters.
If the Docker registry does not require authentication, the docker.publishRegistry configuration can be omitted.
| The registry that the image will be published to is determined by the registry part of the image name ( docker.example.comin these examples).
Ifdocker.publishRegistrycredentials are configured and include aurlparameter, this value is passed to the registry but is not used to determine the publishing registry location. | 
<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>The publish option can be specified on the command line as well, as shown in this example:
$ mvn spring-boot:build-image -Dspring-boot.build-image.imageName=docker.example.com/library/my-app:v1 -Dspring-boot.build-image.publish=trueWhen using the publish option on the command line with authentication, you can provide credentials using properties as in this example:
$ 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:v1and reference the properties in the XML configuration:
<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>Builder Cache and Workspace Configuration
The CNB builder caches layers that are used when building and launching an image. By default, these caches are stored as named volumes in the Docker daemon with names that are derived from the full name of the target image. If the image name changes frequently, for example when the project version is used as a tag in the image name, then the caches can be invalidated frequently.
The cache volumes can be configured to use alternative names to give more control over cache lifecycle as shown in the following example:
<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>Builders and buildpacks need a location to store temporary files during image building. By default, this temporary build workspace is stored in a named volume.
The caches and the build workspace can be configured to use bind mounts instead of named volumes, as shown in the following example:
<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 Configuration
Docker Configuration for minikube
The plugin can communicate with the Docker daemon provided by minikube instead of the default local connection.
On Linux and macOS, environment variables can be set using the command eval $(minikube docker-env) after minikube has been started.
The plugin can also be configured to use the minikube daemon by providing connection details similar to those shown in the following example:
<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
The plugin can communicate with a podman container engine.
The plugin can be configured to use podman local connection by providing connection details similar to those shown in the following example:
<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>| With the colimaCLI installed, the commandpodman info --format='{{.Host.RemoteSocket.Path}}'can be used to get the value for thedocker.hostconfiguration property shown in this example. | 
Docker Configuration for Colima
The plugin can communicate with the Docker daemon provided by Colima.
The DOCKER_HOST environment variable can be set by using the following command:
$ export DOCKER_HOST=$(docker context inspect colima -f '{{.Endpoints.docker.Host}}')The plugin can also be configured to use Colima daemon by providing connection details similar to those shown in the following example:
<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 Configuration for Authentication
If the builder or run image are stored in a private Docker registry that supports user authentication, authentication details can be provided using docker.builderRegistry parameters as shown in the following example:
<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>If the builder or run image is stored in a private Docker registry that supports token authentication, the token value can be provided using docker.builderRegistry parameters as shown in the following example:
<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>