This repository contains a template for running OpenXPKI with the official debian packages. We also provide a docker-compose.yml for easy startup and management. This container is supposed to run behind an nginx reverse-proxy to provide https, therefore we provide a tested nginx configuration example.
This container is designed to run with MySql but can be changed to use other database systems.
A quickstart can be used for testing as it contains everything that is needed. This docker-compose contains default credentials for the database, that can be changed. When starting the containers with docker-compose up, a database container is created and linked to openxpki as mysql. The OpenXPKI sampleconfig.sh will be called after the database has been created and initialized.
git clone https://github.com/DimeOne/docker-openxpki.git
cd docker-openxpki
docker-compose up -d && docker-compose logs -f
Start browser and navigate to http://127.0.0.1:8080/openxpki
All userdata is either stored in the MySql database or as files in the openxpki configuration. When using the docker-compose.yml, all folders, including configuration, logs and MySql database files are stored as folders in the same directory as the docker-compose.yml.
- mysql_data
- config
- logs
There are three parts of configuration that have to be considered. But will be created using defaults if not changed.
This container is designed to run alongside a mysql container or atleast have the connection details configured using environment variables. When using the docker-compose.yml, valid default values will be supplied, but should be changed before starting the containers the first time.
- APP_DB_NAME=openxpki
- APP_DB_HOST=mysql
- APP_DB_PORT=3306
- APP_DB_USER=openxpki
- APP_DB_PASS=openxpki
- APP_DB_ROOT_PASS=super-secret-password
The mysql port does not have to be exported when linked.
When these variables are set, values in database.yml will be overwritten by these.
APP_DB_ROOT_PASS is only required when creating a dabatase and can be omitted if the database already exists.
The configuration of the pki is done within /etc/openxpki.
If this folder doesn't contain a config.d folder, new example configuration files will be extracted to this directory.
When this container is started without parameters and no .initiated file in the config folder, the default sampleconfig.sh will be run oncec to create and import new certificates. The script sampleconfig.sh may be fine when running a demo but should be edited before being used in production.
To use a custom sampleconfig.sh, just create a customconfig.sh in the configuration directory, that will be called instead.
These files are used to configure OpenXPKI, consult the OpenXPKI manual for further information.
This container has no https configuration and is expected to be run behind an nginx reverse-proxy.
An example configuration may be found within this repository at configs/nginx/openxpki
This container is expected to be linked to a MySql server or have the connection details passed through environment variables.
The following commands can be used to access specific setup steps directly, by launching the container with the following commands:
Creates a new database from the given environment variables. Requires MySql root password to be set.
Initiate the database with the mysql schema provided by openxpki.
Create certificates from sampleconfig.sh or customconfig.sh
Wait for a succesful database connection using credentials from environment variables.
Wait for a succesful database connection using root and credentials from environment variables.
Run the Servers.
Show the versions of the used tools.
- APP_DB_NAME = openxpki
- APP_DB_HOST = mysql
- APP_DB_PORT = 3306
- APP_DB_USER = openxpki
- APP_DB_PASS = openxpki
- APP_DB_ROOT_PASS = super-secret-password
- So much documentation.
- Generalize configuration for other dbs?
- Unable to run openxpki start --foreground properly
- See: openxpki/openxpki#538
- might cause problems with process reaping and leave zombies
- prevents running the processes through an external supervisor like s6 or supervisord