Restructure "Building Container Images" section

See gh-22296
pull/22996/head
Sebastiaan Fernandez 4 years ago committed by Stephane Nicoll
parent 7028231626
commit c50a5b395b

@ -8176,9 +8176,12 @@ If you need the `Mockk` equivalent of the Mockito specific <<boot-features-testi
== Building Container Images
Spring Boot applications can be containerized either by <<building-docker-images,packaging them into Docker images>>, or by <<using-buildpacks,using Buildpacks to create docker compatible container images that you can run anywhere>>.
[[building-docker-images]] [[building-docker-images]]
== Building Docker Images === Building Docker images
Spring Boot applications can be containerized by packaging them into 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. 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. However, there are various downsides to copying and running the fat jar as is in the docker image.
Theres always a certain amount of overhead when running a fat jar without unpacking it, and in a containerized environment this can be noticeable. Theres always a certain amount of overhead when running a fat jar without unpacking it, and in a containerized environment this can be noticeable.
@ -8186,7 +8189,7 @@ 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, its often better to separate things a bit more. Since you probably recompile your code more often than you upgrade the version of Spring Boot you use, its 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. 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. 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. 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. 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.
@ -8223,7 +8226,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. 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. 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.
Heres how you can launch your jar with a `layertools` jar mode: Heres how you can launch your jar with a `layertools` jar mode:
@ -8281,7 +8284,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. You can use some combination of `unzip` and `mv` to move things to the right layer but jarmode simplifies that.
[[using-buildpacks]]
=== Buildpacks === Buildpacks
Dockerfiles are just one way to build docker images. 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. Another way to build docker images is directly from your Maven or Gradle plugin, using buildpacks.

Loading…
Cancel
Save