-
Notifications
You must be signed in to change notification settings - Fork 3
Building Docker Images
PowerAuth Docker documentation has been moved to: https://developers.wultra.com/docs/develop/powerauth-docker/Building-Docker-Images
Please use the new developer portal to access documentation.
This document describes how to build Docker images.
- Docker. (version 17.3.1+) Obviously, you need Docker to use our Docker images. :-) Docker is easy to install, follow the official documentation.
- Docker Compose. (version 1.11.2+) Compose is an extension to Docker that simplifies container image deployment and configuration management.
- Unix-based operating system. While our software can run in Windows as well, we optimized our scripts for Linux / Unix environment. We proudly build all our packages on Mac OS X.
To install PowerAuth 2.0 stack in your Docker instance, perform following steps:
First, clone the repository with Docker related files:
$ git clone https://github.com/wultra/powerauth-docker.git
Then, add following files in the cloned repository:
- WAR files with required PowerAuth applications, see
deploy/images/readme.txt
for details. - JAR files with JDBC drivers required for JPA connectivity, see
deploy/lib/readme.txt
for details.
Note: While you need to provide Oracle JDBC driver, we do not provide Docker images with Oracle database. Driver file (ojdbc6.jar
) is mainly required in a real production database, in case applications are configured so that they point to a production Oracle DB.
If you don't do anything with the configuration, everything will just work on your local machine.
Each application has a context XML file (see deploy/conf
folder), where you can configure properties for your particular instance. See the documentation of the respective applications to learn about the meaning of properties.
In case you would like to run PowerAuth stack with provided MySQL images for Docker, you may also need to customize MySQL init scripts stored in deploy/data/mysql
(only in case you would like to pre-populate database with data).
Note that by default, MySQL images are mounted to /var/lib/powerauth/**
path, that does not have to be accessible. To customize MySQL instance in containers (root password, host folder mapping), you can change the related environment variables in .env
file. You can always override these variables while launching docker-compose up
command as well, for example (to use volatile /tmp/powerauth/**
folders):
POWERAUTH_MYSQL_PATH=/tmp/powerauth/mysql \
POWERAUTH_PUSH_MYSQL_PATH=/tmp/powerauth/mysql-push \
docker-compose up -d
In case you want to include Web Flow, use:
POWERAUTH_MYSQL_PATH=/tmp/powerauth/mysql \
POWERAUTH_PUSH_MYSQL_PATH=/tmp/powerauth/mysql-push \
POWERAUTH_WEBFLOW_MYSQL_PATH=/tmp/powerauth/mysql-webflow \
docker-compose -f docker-compose-pa-all.yml up -d
Finally, you can edit PowerAuth Admin users by modifying deploy/data/ldap/ldap-local.ldiff
file.
Run build.sh
command from the root of the repository, wait for the images to be built.
$ sh build.sh
This will build all images, tagged as latest
(latest tag is always produced) and also ${PRODUCT_VERSION}.${BUILD_NUMBER}
. By default, following values are used:
-
${PRODUCT_VERSION}
- Based on PowerAuth stack product version, for example2017.11
. -
${BUILD_NUMBER}
- Current Unix timestamp (seconds).
Resulting tag name may look like this: 2017.11.1511954657
.
You may override the tag name by overriding either:
-
BUILD
variable -BUILD=1 sh build.sh
will result in tagslatest
and2017.11.1
. -
TAG
variable -TAG=1.0.1 sh build.sh
will result in tagslatest
and1.0.1
.
Run Docker Compose in the root folder:
$ docker-compose up -d
See docker-compose.yml
for the default configuration.
In case you want to run the whole PowerAuth stack including Web Flow, you can use:
$ docker-compose -f docker-compose-pa-all.yml up -d
All sources are licensed using Apache 2.0 license, you can use them with no restriction. If you are using PowerAuth 2.0, please let us know. We will be happy to share and promote your project.