Caching Jar dependencies for Maven-based Docker builds

I’m building a Docker image from this Dockerfile:

FROM maven:3.3.3-jdk-8

ADD pom.xml /work/pom.xml
RUN mvn dependency:go-offline --fail-never

ADD ["src", "/work/src"]
RUN ["mvn", "package"]

With this Dockerfile, I force to download the dependencies before packaging my Java project. Thus, I don’t have to redownload the dependencies every time I changed a file from my src directory.

  • Ansible docker_container command failing with no output
  • Access named volume from container when not running as root?
  • docker -v and symlinks
  • fuser returns Cannot Permission denied
  • Could not run mvc 6 on Docker
  • File locks support in Docker volumes of NFS4 shares
  • But, there is a problem and this problem is depending on the version of Maven (base image). In fact, the dependencies are downloaded but they are not persisted into the ~/.m2 directory of the container. It’s empty. Thus, when I change some source file all the dependencies are redownloaded.

    However, I noticed that if I change the version of Maven from the base image (for example FROM maven:3.2.5-jdk-8), it works.

    Very strange, isn’t it?

  • How to make a custom docker image based on both Node and Java?
  • How to create Postgres backups from docker container
  • chrome fake audioinput with real audio output?
  • how to bind specific interface in docker container?
  • How do you set an ssh key for docker image containing a private git repo?
  • Not able to connect to HBase ( Zookeeper ) running on Vagrant
  • 2 Solutions collect form web for “Caching Jar dependencies for Maven-based Docker builds”

    I’m afraid it’s because of this VOLUME instruction they’ve added:

    It makes /root/.m2 a volume and thus any changes to that folder made by build steps are not brought on to the following build containers.

    There is a new instruction regarding this topic:

    The $MAVEN_CONFIG dir (default to /root/.m2) is configured as a volume so anything copied there in a Dockerfile at build time is lost. For that the dir /usr/share/maven/ref/ is created, and anything in there will be copied on container startup to $MAVEN_CONFIG.

    To create a pre-packaged repository, create a pom.xml with the dependencies you need and use this in your Dockerfile. /usr/share/maven/ref/settings-docker.xml is a settings file that changes the local repository to /usr/share/maven/ref/repository, but you can use your own settings file as long as it uses /usr/share/maven/ref/repository as local repo.

    Docker will be the best open platform for developers and sysadmins to build, ship, and run distributed applications.