commit
e03ac4bed6
|
|
@ -36,7 +36,7 @@ Once you have unpacked the jar file, you can also get an extra boost to startup
|
|||
NOTE: Using the `JarLauncher` over the application's main method has the added benefit of a predictable classpath order.
|
||||
The jar contains a `classpath.idx` file which is used by the `JarLauncher` when constructing the classpath.
|
||||
|
||||
More efficient container images can also be created by <<spring-boot-features.adoc#building-docker-images,creating separate layers>> for your dependencies and application classes and resources (which normally change more frequently).
|
||||
More efficient container images can also be created by <<spring-boot-features.adoc#boot-features-container-images-docker,creating separate layers>> for your dependencies and application classes and resources (which normally change more frequently).
|
||||
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -8207,9 +8207,14 @@ If you need the `Mockk` equivalent of the Mockito specific <<boot-features-testi
|
|||
|
||||
|
||||
|
||||
[[building-docker-images]]
|
||||
== Building Docker Images
|
||||
Spring Boot applications can be containerized by packaging them into Docker images.
|
||||
[[boot-features-container-images]]
|
||||
== Building Container Images
|
||||
Spring Boot applications can be containerized either by <<boot-features-container-images-docker,packaging them into Docker images>>, or by <<boot-features-container-images-buildpacks,using Buildpacks to create docker compatible container images that you can run anywhere>>.
|
||||
|
||||
|
||||
|
||||
[[boot-features-container-images-docker]]
|
||||
=== Building Docker images
|
||||
A typical Spring Boot fat jar can be converted into a Docker image by adding just a few lines to a Dockerfile that can be used to build the image.
|
||||
However, there are various downsides to copying and running the fat jar as is in the docker image.
|
||||
There’s always a certain amount of overhead when running a fat jar without unpacking it, and in a containerized environment this can be noticeable.
|
||||
|
|
@ -8217,7 +8222,9 @@ The other issue is that putting your application's code and all its dependencies
|
|||
Since you probably recompile your code more often than you upgrade the version of Spring Boot you use, it’s often better to separate things a bit more.
|
||||
If you put jar files in the layer before your application classes, Docker often only needs to change the very bottom layer and can pick others up from its cache.
|
||||
|
||||
=== Layering Docker Images
|
||||
|
||||
|
||||
==== Layering Docker Images
|
||||
To make it easier to create optimized Docker images that can be built with a dockerfile, Spring Boot supports adding a layer index file to the jar.
|
||||
It provides a list of layers and the parts of the jar that should be contained within them.
|
||||
The list of layers in the index is ordered based on the order in which the layers should be added to the Docker/OCI image.
|
||||
|
|
@ -8254,7 +8261,7 @@ For Gradle, refer to the {spring-boot-gradle-plugin-docs}#packaging-layered-jars
|
|||
|
||||
|
||||
|
||||
=== Writing the Dockerfile
|
||||
==== Writing the Dockerfile
|
||||
When you create a jar containing the layers index file, the `spring-boot-jarmode-layertools` jar will be added as a dependency to your jar.
|
||||
With this jar on the classpath, you can launch your application in a special mode which allows the bootstrap code to run something entirely different from your application, for example, something that extracts the layers.
|
||||
Here’s how you can launch your jar with a `layertools` jar mode:
|
||||
|
|
@ -8312,7 +8319,7 @@ Of course, a Dockerfile can be written without using the jarmode.
|
|||
You can use some combination of `unzip` and `mv` to move things to the right layer but jarmode simplifies that.
|
||||
|
||||
|
||||
|
||||
[[boot-features-container-images-buildpacks]]
|
||||
=== Buildpacks
|
||||
Dockerfiles are just one way to build docker images.
|
||||
Another way to build docker images is directly from your Maven or Gradle plugin, using buildpacks.
|
||||
|
|
|
|||
Loading…
Reference in New Issue