[BETA] Docker Compose

WARNING! This is a new feature, currently in BETA. Only these containers are available: MySQL, PostgreSQL, MongoDB, Cassandra, Elasticsearch, SonarQube.

Description

When generating your application, if you choose MySQL, PostgreSQL, MongoDB or Cassandra, some docker-compose files (dev.yml, prod.yml, sonar.yml) are generated in your folder project src/main/docker/.

If you choose Elasticsearch as search engine, the configuration will be included in prod.yml.

So you can use docker-compose to start your database in development or production profile.

All these images come from the official Docker Hub:

Prerequisites

You have to install Docker and Docker Compose:

Working with databases

Note

Please note: based on your OS your DOCKER_HOST_IP will differ. On Linux, it will be simply your localhost. For Mac/Windows, you will have to obtain the IP using following command: docker-machine ip default or docker-machine env default.

You have to use this DOCKER_HOST_IP instead of localhost for databases in your application-dev.yml and application-prod.yml files.

Starting MySQL, PostgreSQL or MongoDB

In development profile:

docker-compose -f src/main/docker/dev.yml up -d

In production profile (it will start Elasticsearch too if you selected it as search engine):

docker-compose -f src/main/docker/prod.yml up -d

Starting Cassandra the first time

In development profile:

  • Build the image:

docker-compose -f src/main/docker/dev.yml build

  • Start the container (it will show the container id):

docker-compose -f src/main/docker/dev.yml up -d

  • Copy the cql scripts inside the container:

docker cp src/main/resources/config/cql/ "container id":/

  • Initialize the database by creating the Keyspace and the Tables:

docker exec -it "container id" init

  • After using entity sub generator, update the cql scripts inside the container:

docker cp src/main/resources/config/cql/ "container id":/

  • Create the tables:

docker exec -it "container id" entities

In production profile:

  • Build the image:

docker-compose -f src/main/docker/prod.yml build

  • Start the container (it will show the container id):

docker-compose -f src/main/docker/prod.yml up -d

  • Copy the cql scripts inside the container:

docker cp src/main/resources/config/cql/ "container id":/

  • Initialize the database by creating the Keyspace and the Tables:

docker exec -it "container id" init

  • Add X other nodes:

docker-compose -f src/main/docker/prod.yml scale <name_of_your_app>-cassandra-node=X

  • You can manage all nodes with OpsCenter: http://localhost:8888

  • Before starting your application in production profile, add in your application-prod.yml every IP of containers to the key spring.data.cassandra.contactPoints

  • After using entity sub generator, update the cql scripts inside the container:

docker cp src/main/resources/config/cql/ "container id":/

  • Create the tables:

docker exec -it "container id" entities

Starting Cassandra the next times

In development profile:

docker-compose -f src/main/docker/dev.yml up -d

In production profile:

docker-compose -f src/main/docker/prod.yml up -d

Working with Sonar

When generating your application, the src/main/docker/sonar.yml is generated in your folder project. So you can start a sonar instance to analyze your code:

Start a sonar instance :

docker-compose -f src/main/docker/sonar.yml up -d

Analyze your code:

mvn sonar:sonar or ./gradlew sonar

You can access to sonar: http://localhost:9000

Common commands

List the containers

You can use docker ps -a to list all the containers

$ docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
fc35e1090021        mysql               "/entrypoint.sh mysql"   4 seconds ago       Up 4 seconds        0.0.0.0:3306->3306/tcp   sampleApplication-mysql

Stop the containers

In development profile:

docker-compose -f src/main/docker/dev.yml stop

In production profile:

docker-compose -f src/main/docker/prod.yml stop

You can use directly docker:

docker stop "container id"

When you stop a container, the data are not deleted, unless you delete the container.

Delete a container

Be carefull! All data will be deleted:

docker rm "container id"