Docker Java Example Series
Converting from the transmode gradle plugin to the bmuschko remote api gradle plugin was pretty straightforward. Other than importing and applying the plugin, the code to get local docker image creation working is as follows:
Note that bmuschko does support multiple image tags, and I took advantage of that to get the versioned tag as well as the "latest" tag.
REPOSITORY TAG IMAGE ID CREATED SIZE ryanmckay/java-docker-example 0.0.1-SNAPSHOT 7fd01d5b247f 6 seconds ago 115MB ryanmckay/java-docker-example latest 7fd01d5b247f 6 seconds ago 115MBI tagged the code repo at this point v0.4.1
Java Application plugin
In addition to the low-level remote api plugin, bmuschko offers an opinionated docker-java-application plugin based on the application gradle plugin. Using the opinionated plugin cuts down dramatically on the boilerplate in the build.gradle:
Unfortunately, this task only supports one tag. By default, you get the versioned one.
REPOSITORY TAG IMAGE ID CREATED SIZE ryanmckay/java-docker-example 0.0.1-snapshot 415a9e4b201d 3 seconds ago 115MB
The generated Dockerfile looks like this:
As an interesting side note, the ADD Dockerfile directive has special behavior when the file being added is a tar file. In that case, it unpacks it to the destination.
As an interesting side note, the ADD Dockerfile directive has special behavior when the file being added is a tar file. In that case, it unpacks it to the destination.
The application gradle plugin is a more generic method of packaging up a java application than that offered by the spring boot plugin. It creates a tar file containing the application jar and all the dependency jars. It also contains a shell script for launching the application, which has OS detection and some OS-specific config.
$ tar tf build/distributions/java-docker-example-0.0.1-SNAPSHOT.tar java-docker-example-0.0.1-SNAPSHOT/ java-docker-example-0.0.1-SNAPSHOT/lib/ java-docker-example-0.0.1-SNAPSHOT/lib/java-docker-example-0.0.1-SNAPSHOT.jar java-docker-example-0.0.1-SNAPSHOT/lib/spring-boot-starter-1.5.4.RELEASE.jar java-docker-example-0.0.1-SNAPSHOT/lib/spring-boot-starter-web-1.5.4.RELEASE.jar ... java-docker-example-0.0.1-SNAPSHOT/bin/ java-docker-example-0.0.1-SNAPSHOT/bin/java-docker-example java-docker-example-0.0.1-SNAPSHOT/bin/java-docker-example.bat
I started using gradle about the same time I started using spring boot (which has its own gradle plugin with executable jar packaging), so wasn't familiar with the application plugin. It makes sense that bmuschko would base the opinionated plugin on that, so it can support all types of java applications, not just spring boot. However, since I plan to exclusively use spring boot for the foreseeable future, and can completely specify the execution environment in Docker (so don't need the OS-related functionality provided by the application plugin), I want to stick with Spring Boot application packaging and running.
I left the modifications in a branch tagged as v0.4.2
I left the modifications in a branch tagged as v0.4.2
Nebula docker gradle plugin
Netflix publishes a set of plugins for gradle called Nebula. The nebula-docker-plugin is another opinionated plugin built on top of the bmuschko and application plugins. It doesn't seem to add a lot beyond the bmuschko application plugin, other than the concept of separate test and production repositories for publishing docker images. I'm going to look into docker deployment models next so it might come into play there.
No comments:
Post a Comment