Public | Automated Build

Last pushed: a year ago
Short Description
Guacamole Database for Docker.
Full Description

Guacamole Database Image


This is my minimal customized Guacamole Database image based on Alpine (with my alpine image).
No root process.
The script will create the first database, a standard user that can interact from a specified host and network with the DB container.
If you have some sql script (to import data) to execute, put it at /conf/$DB_init.sql. It will be launch with the script.

Guacamole Images

• Client Part : khirin/guacamole-client
• Server Part : khirin/guacamole-server
• DB Part : khirin/guacamole-db


• Packages from khirin/alpine
• mariadb
• mariadb-client

Default Configuration

• Configuration from khirin/alpine
• Default user (UID) : mysql (2000)
• Default group (GID) : mysql (2000)
• Default port : 3306
• Database name : guacamole
• DB Standard User : guacamole
• DB Standard Password : userpassword
• DB Root Password : rootpassword
DB password must be set with base64 coding.


• /scripts (RO) : Start script and db init script.
• /conf (RO) : SQL scripts.
• /var/lib/mysql (RW) : Where all database data will be store.

docker volume create --name data_guacamoledb


• guacamole-network : Network with only the guacamole-db container and the guacamole-client container.

docker network create -o "" guacamole-network


• Run : Will use the default configuration above.
• Build : Example of custom build. You can also directly modify the Dockerfile (I won't be mad, promis !)
• Create : Example of custom create. It is useless to publish the port, expose it is enough to other container(s) on the same network.

• Run
docker run --detach \
                -v "data_guacamoledb:/var/lib/mysql:rw" \
                       -v "/my_script_folder:/scripts:ro" \
                       -v "/my_conf_folder:/conf:ro" \
            --network guacamole-network \
• Build
/bin/docker build \
                --no-cache=true \
                --force-rm \
                --build-arg UID="2000" \
                --build-arg GID="2000" \
                --build-arg PORT="3306" \
                -t repo/guacamole-db .
• Create
/bin/docker create --hostname=guacamole-db \
                --name guacamole-db \
                -v "data_guacamoledb:/var/lib/mysql:rw" \
                -v "/my_script_folder:/scripts:ro" \
                -v "/my_conf_folder:/conf:ro" \
                --env DATABASE="guacamole" \
                --env DB_USER="guacamole" \
                --env DB_USER_PASSWORD="Z3VhY2Ftb2xlCg===" \
                --env DB_ROOT_PASSWORD="cm9vdHBhc3N3b3JkCg==" \
                --env CLIENT_HOST="guacamole-client.guacamole-network" \
                -m 128M --memory-swap 256M \
                --network guacamole-network \


khirin : DockerHub, GitHub


All my images are based on my personal knowledge and inspired by many projects of the Docker community.
If you recognize yourself in some working approaches, you might be one of my inspirations (Thanks!).

Docker Pull Command
Source Repository