activemq-artemis/artemis-docker
Muammer Eroglu fd5b64f035 ARTEMIS-4408 Update docker-run.sh for etc override
ARTEMIS-4408 Update docker-run.sh for etc override

After creating the artemis docker image using the docker-run.sh script,
it is not possible to map a user supplied broker.xml using a volume
mapping. The broker.xml file is not there before instance creation,
so we cannot a static file mapping.

This change introduces an etc-override folder to write over the etc
folder contents. If a folder named etc-override exists inside the
instance folder, its contents will be copied over to etc folder after
instance creation. In order to use custom files that reside in etc,
eg. broker.xml or artemis.profile; it is sufficient to place these
files to a folder and map it to /var/lib/artemis-instance/etc-override
folder of the image.

The usage is also documented in readme.md file under the docker folder.
2023-09-01 11:07:03 -05:00
..
Dockerfile-alpine-11-jre ARTEMIS-4376 add Dockerfile for Alpine + JRE 11 2023-07-28 06:32:01 -04:00
Dockerfile-alpine-17 ARTEMIS-4310 Add Alpine/Java17 based Docker image 2023-07-15 12:04:06 -05:00
Dockerfile-centos7-11 ARTEMIS-3983 Update all base images to use Eclipse-Temurin 2022-09-18 21:54:38 +03:00
Dockerfile-ubuntu-11 ARTEMIS-3983 Update all base images to use Eclipse-Temurin 2022-09-18 21:54:38 +03:00
Dockerfile-ubuntu-11-jre ARTEMIS-3983 Update all base images to use Eclipse-Temurin 2022-09-18 21:54:38 +03:00
docker-run.sh ARTEMIS-4408 Update docker-run.sh for etc override 2023-09-01 11:07:03 -05:00
prepare-docker.sh NO-JIRA Remove dependency on tree utility 2023-08-29 14:55:51 -05:00
readme.md ARTEMIS-4408 Update docker-run.sh for etc override 2023-09-01 11:07:03 -05:00

readme.md

Docker Image Example

This is an example on how you could create your own Docker Image For Apache ActiveMQ Artemis based on CentOS or Ubuntu (Eclipse Temurin JDK images).

Preparing

You need a set of activemq binary distribution files to build the Docker Image. These can be your local distribution files, in which case you need to build the project first, or they can be pulled automatically from the official ActiveMQ release repository.

Using a Local Binary Distribution

If you want to use a local binary distribution, build the project from the root of the ActiveMQ source tree using maven.

mvn install -DskipTests=true

Following the build, the distribution files will be in your local distribution directory.

artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT

In the artemis-docker directory, run the script ./prepare-docker.sh to copy the docker files into your local binary distribution.

Below is shown the command to prepare the build of the Docker Image starting from the local distribution (from the source codes of ActiveMQ Artemis)

# Prepare for build the Docker Image from the local distribution. Replace the 
# {local-distribution-directory} with your directory.
$ ./prepare-docker.sh --from-local-dist --local-dist-path {local-distribution-directory}

The output of the previous command is shown below.

$ ./prepare-docker.sh --from-local-dist --local-dist-path ../artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT

Using ../artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT
Cleaning up ../artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT/docker

Well done! Now you can continue with building the Docker image:

  # Go to ../artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT
  $ cd ../artemis-distribution/target/apache-artemis-2.17.0-SNAPSHOT-bin/apache-artemis-2.17.0-SNAPSHOT

  # For CentOS with full JDK 11
  $ docker build -f ./docker/Dockerfile-centos7-11 -t artemis-centos .

  # For Ubuntu with full JDK 11
  $ docker build -f ./docker/Dockerfile-ubuntu-11 -t artemis-ubuntu .

  # For Ubuntu with just JRE 11
  $ docker build -f ./docker/Dockerfile-ubuntu-11-jre -t artemis-ubuntu-jre .

  # For Alpine with full JDK 17
  $ docker build -f ./docker/Dockerfile-alpine-17 -t artemis-alpine .

  # For Alpine with just JRE 11
  $ docker build -f ./docker/Dockerfile-alpine-11-jre -t artemis-alpine-jre .

  # For Ubuntu on Linux ARMv7/ARM64 with full JDK
  $ docker buildx build --platform linux/arm64,linux/arm/v7 --push -t {your-repository}/apache-artemis:2.17.0-SNAPSHOT -f ./docker/Dockerfile-ubuntu-11 .

Note: -t artemis-centos and -t artemis-ubuntu are just tag names for the purpose of this guide

For more info see readme.md.

Using the Official ActiveMQ Binary Release

The command to prepare the build of the Docker Image starting from the official release of ActiveMQ Artemis is shown below

# Prepare for build the Docker Image from the release version. Replace the
# {release-version} with the version that you want 
$ ./prepare-docker.sh --from-release --artemis-version {release-version}

The output of the previous command is shown below.

$ ./prepare-docker.sh --from-release --artemis-version 2.16.0
Creating _TMP_/artemis/2.16.0
Downloading apache-artemis-2.16.0-bin.tar.gz from https://downloads.apache.org/activemq/activemq-artemis/2.16.0/...
################################################################################################################################################################################################################################ 100,0%
Expanding _TMP_/artemis/2.16.0/apache-artemis-2.16.0-bin.tar.gz...
Removing _TMP_/artemis/2.16.0/apache-artemis-2.16.0-bin.tar.gz...

Well done! Now you can continue with building the Docker image:

  # Go to _TMP_/artemis/2.16.0
  $ cd _TMP_/artemis/2.16.0

  # For CentOS with full JDK
  $ docker build -f ./docker/Dockerfile-centos7-11 -t artemis-centos .

  # For Ubuntu with full JDK
  $ docker build -f ./docker/Dockerfile-ubuntu-11 -t artemis-ubuntu .

  # For Ubuntu with just JRE
  $ docker build -f ./docker/Dockerfile-ubuntu-11-jre -t artemis-ubuntu .

  # For Ubuntu on Linux ARMv7/ARM64 with full JDK
  $ docker buildx build --platform linux/arm64,linux/arm/v7 --push -t {your-repository}/apache-artemis:2.16.0 -f ./docker/Dockerfile-ubuntu-11 .

Note: -t artemis-centos and -t artemis-ubuntu are just tag names for the purpose of this guide

For more info read the readme.md

Building

Go to $ARTEMIS_DIST where you prepared the binary with Docker files.

For CentOS

From within the $ARTEMIS_DIST folder:

$ docker build -f ./docker/Dockerfile-centos7-11 -t artemis-centos .

For Ubuntu

From within the $ARTEMIS_DIST folder:

$ docker build -f ./docker/Dockerfile-ubuntu-11 -t artemis-ubuntu .

Smaller Ubuntu image with just JRE

From within the $ARTEMIS_DIST folder:

$ docker build -f ./docker/Dockerfile-ubuntu-11-jre -t artemis-ubuntu .

For Ubuntu (Build for linux ARMv7/ARM64)

$ docker buildx build --platform linux/arm64,linux/arm/v7 --push -t {your-repository}/apache-artemis:2.17.0-SNAPSHOT -f ./docker/Dockerfile-ubuntu-11 .

Note: -t artemis-centos and -t artemis-ubuntu are just tag names for the purpose of this guide

Environment Variables

Environment variables determine the options sent to artemis create on first execution of the Docker container. The available options are:

ARTEMIS_USER

The administrator username. The default is artemis.

ARTEMIS_PASSWORD

The administrator password. The default is artemis.

ANONYMOUS_LOGIN

Set to true to allow anonymous logins. The default is false.

EXTRA_ARGS

Additional arguments sent to the artemis create command. The default is --http-host 0.0.0.0 --relax-jolokia. Setting this value will override the default. See the documentation on artemis create for available options.

Final broker creation command:

The combination of the above environment variables results in the docker-run.sh script calling the following command to create the broker instance the first time the Docker container runs:

${ARTEMIS_HOME}/bin/artemis create --user ${ARTEMIS_USER} --password ${ARTEMIS_PASSWORD} --silent ${LOGIN_OPTION} ${EXTRA_ARGS}

Note: LOGIN_OPTION is either --allow-anonymous or --require-login depending on the value of ANONYMOUS_LOGIN.

Mapping point

  • /var/lib/artemis-instance

It's possible to map a folder as the instance broker. This will hold the configuration and the data of the running broker. This is useful for when you want the data persisted outside of a container.

Lifecycle of the execution

A broker instance will be created during the execution of the instance. If you pass a mapped folder for /var/lib/artemis-instance an image will be created or reused depending on the contents of the folder.

Overriding files in etc folder

You can use customized configuration for the artemis instance by replacing the files residing in etc folder with the custom ones, eg. broker.xml or artemis.profile. Put the replacement files inside a folder and map it as a volume to:

  • /var/lib/artemis-instance/etc-override

The contents of etc-override folder will be copied over to etc folder after the instance creation. Therefore, the image will always start with user-supplied configuration.

It you are mapping the whole var/lib/artemis-instance to an outside folder for persistence, you can place an etc-override folder inside the mapped one, its contents will again be copied over etc folder after creating the instance.

Running a CentOS image

The image just created in the previous step allows both stateless or stateful runs. The stateless run is achieved by:

$ docker run --rm -it -p 61616:61616 -p 8161:8161 artemis-centos 

The image will also support mapped folders and mapped ports. To run the image with the instance persisted on the host:

docker run -it -p 61616:61616 -p 8161:8161 -v <broker folder on host>:/var/lib/artemis-instance artemis-centos 

where <broker folder on host> is a folder where the broker instance is supposed to be saved and reused on each run.