Container setup

Prerequisites

Container tools

A container management CLI is required such as podman-compose or docker compose (Compose V2). Docker Swarm has not been tested and may not work. The following versions are known to work:

  • Podman version 4.3.1 with podman-compose version 1.0.3 on Debian 12

  • Docker version 27.2.0 with docker compose version 2.29.2 on Debian 12

Podman handles rootless containers.

Image building

Node.js and npm are required to build the container images. Vue.js presently requires Node.js 16 or newer. The following versions are known to work:

  • Node.js version 18.19.0 on Debian 12

  • npm version 9.2.0 and 10.8.2 on Debian 12

General setup

Configure the docker/.env_docker file

Create a file .env_docker in the docker directory using env_docker_example as template. Environment variables defined in this file are used to build the images.

Configure the .env file

Create a file .env in the same directory as the YAML file used to define the services i.e. docker-compose.yml or docker-compose-db-only.yml, using env_example as template. This is the environment file used by compose. For development, this file is typically located in the docker directory (same location as .env_docker), but under production it may be located in a separate deployment directory.

Set up the local directories

Under your deployment directory, or under the docker directory in development setup, create the directory structure for the database:

./scripts/create_local_folders.sh

In particular, the following files are created:

  • secrets/mariadb-root: Password for the root user for the MariaDB database.

  • secrets/mariadb-scimodom: Password for the scimodom user for the MariaDB database.

Production setup

Build the images

cd docker/db_container
./build.sh
cd ../app_container
./build.sh

Optional: copy to a live instance

If the images are built on a different machine, or if multiple deployments are run on the same container host, the required data must be deployed to that system or a separate folder per instance.

In case of a deployment to a different container host, the following data need to be transferred:

  • The images, e.g. via a Docker repository - The database image e.g. scimodom_db:latest - The application image e.g. scimodom_app:latest

  • The docker/scripts folder and the necessary import tables (import folder)

  • The docker-compose.yml file

  • The .env file

If multiple instances are run on the same host, a separate folder needs to be created for each instance. Make sure that the ports, paths and names in the .env files don’t collide!

Starting and stopping the containers

# or docker compose
podman-compose -f docker-compose.yml up -d

And to stop:

# or docker compose
podman-compose -f docker-compose.yml down

Development setup

The database can be run using a container and connected with the application running locally by using docker-compose-db-only.yml. The .env file needs a few variables only, see env_example (database only).

Set up the local directories

For development, running

./scripts/create_local_folders.sh

does not create the development database folder, this must be done manually. The name of this folder matches the value from HOST_DEV_DB_DATA_DIR defined in the .env file, e.g.

# if HOST_DEV_DB_DATA_DIR=./db_data_dev
# in the docker/ directory
mkdir db_data_dev

Build the images

cd docker/db_container
./build.sh

Starting and stopping the database container

The database container must be started under the docker directory:

# or docker compose
podman-compose -f docker-compose-db-only.yml up -d

And to stop:

# or docker compose
podman-compose -f docker-compose-db-only.yml down

Backup and restore

The setup described above supplies two scripts:

  • ./scripts/pre_backup.sh: Dumps the database to the HOST_BACKUP_DIR. Run it before doing a file-level backup, e.g. as “pre” script of your backup solution.

  • ./scripts/post_restore.sh: Load the database from HOST_BACKUP_DIR. Run it just after you restored that folder from a suitable backup.

Troubleshooting

Manual database connection

To directly connect to the database:

# or docker
podman exec -it docker_scimodom_db_1 mariadb -u root -p scimodom

Use the password found in secrets/mariadb-root. Also podman-compose/docker-compose may be used. In case of the ‘db-only’ DEV setup one may do this:

docker podman-compose -f docker-compose-db-only.yml  exec scimodom_db_dev mariadb -u root -p scimodom