Public | Automated Build

Last pushed: a month ago
Short Description
Complete Dockercontainer for a Kivitendo installation. Integrates Postgres Apache and Kivitendo
Full Description


Docker Build for Kivitendo a erp solution for small businesses

Table of Contents


Dockerfile to build a Kivitendo container image which can be linked to other containers.
Will install Postgres and Apache2 and all the necessary packages for Kivitendo.


If you find this image useful here's how you can help:

  • Send a Pull Request with your awesome new features and bug fixes
  • Help new users with Issues they may encounter

Reporting Issues

Docker is a relatively new project and is active being developed and tested by a thriving community of developers and testers and every release of docker features many enhancements and bugfixes.

Given the nature of the development and release cycle it is very important that you have the latest version of docker installed because any issue that you encounter might have already been fixed with a newer docker release.

For ubuntu users I suggest installing docker using docker's own package repository since the version of docker packaged in the ubuntu repositories are a little dated.

Here is the shortform of the installation of an updated version of docker on ubuntu.

sudo apt-get purge
curl -s | sudo sh
sudo apt-get update
sudo apt-get install lxc-docker


Pull the latest version of the image from the docker index. This is the recommended method of installation as it is easier to update image in the future. These builds are performed by the Docker Trusted Build service.

docker pull drnoa/kivitendo-docker

Alternately you can build the image yourself.

git clone
cd kivitendo_docker
docker build -t="<name_of_your_container>" .

Quick Start

Run the Kivitendo image

docker run --name <name_of_your_container> -d drnoa/kivitendo_docker

Check the ip of your docker container

docker ps -q | xargs docker inspect | grep IPAddress | cut -d '"' -f 4

Got to the administrative interface of kivitendo using the password: admin123 and configure the database. All database users (kivitendo and docker) use docker as password.

To test if the postgresql server is working properly, try connecting to the server.

psql -U postgres -h $(docker inspect --format {{.NetworkSettings.IPAddress}} <name_of_your_container>)


Data Store

For data persistence a volume should be mounted at /var/lib/postgresql.

The updated run command looks like this.

docker run --name <name_of_your_container> -d \
  -v /opt/postgresql/data:/var/lib/postgresql drnoa/kivitendo_docker:latest

This will make sure that the data stored in the database is not lost when the image is stopped and started again.

Securing the server

By default 'docker' is assigned as password for the postgres user.

You can change the password of the postgres user

psql -U postgres -h $(docker inspect --format {{.NetworkSettings.IPAddress}} <name_of_your_container>)
\password postgres

Build container from Dockerfile

You can build the container from the Dockerfile in

simply clone the git repo localy and then build

git clone
cd kivitendo_docker
sudo docker build .

When you build the container using the Dockerfile you have the possibility to change some parameters
for example the used postgressql version or the database locale (default ist de_DE).
Its also possible to change the postgred passwords.
To change this paramters simply edit the Dockerfile and edit the following values:

ENV postgresversion 9.3
ENV locale de_CH
ENV postrespassword docker


To upgrade to newer releases, simply follow this 3 step upgrade procedure.

  • Step 1: Stop the currently running image
docker stop <name_of_your_container>
  • Step 2: Update the docker image.
docker pull drnoa/kivitendo_docker:latest
  • Step 3: Start the image
docker run --name <name_of_your_container> -d [OPTIONS] drnoa/kivitendo_docker:latest
Docker Pull Command
Source Repository