Public | Automated Build

Last pushed: 12 days ago
Short Description
Image for running a Contao-based website
Full Description

Docker image for CONTAO

The Dockerfile compiles into a Docker image for a plain Contao CMS instance. The Dockerfile-personalised can be used to create an image including all extensions.


A detailed explanation on how to use the images to run a Contao website is available at Dockerising a Contao website.

The Contao site in the image from the Dockerfile is basically fully functional. It contains a plain Contao installation. However, it does not contain any plugins yet. Thus, you should use the image to create a personalised Docker image locally, which uses your composer.json to install extensions etc. The file Dockerfile-personalised may help as a template.

From that personalised image, all you need to do is mounting personalised files "over" the default versions into the image. Typically you would mount:

  • files/ - those are your uploaded images etc
  • templates/ - themes and layout adjustments etc
  • system/config/localconfig.php - configuration for database etc

plus maybe other configuration files in system/config/...

Simple Example

Let's say you keep your files in $PATH and your personalised Docker image is called conato-personalised, then you would run your website as:

docker run --rm -it \
    -p 8080:80 \
    -v $PATH/files/:/var/www/html/files/ \
    -v $PATH/templates/:/var/www/html/templates/ \
    -v $PATH/system/config/localconfig.php:/var/www/html/system/config/localconfig.php \

This basically mounts your files from PATH to the proper locations in /var/www/html of the container and bind its port 80 to port 8080 of your server. Thus, you should be able to access the Contao instance at

Depending on your configuration you may want to link a MySQL container etc.

Using Docker-Compose and a MySQL Database

Let's again say your individual data is stored in $PATH and you want to run the website using a MySQL database, then you can compose the following containers

version: '2'

      build: /path/to/personalised/Dockerfile
      restart: unless-stopped
      container_name: contao
        - contao_db
        - "8080:80"
        - $PATH/files:/var/www/html/files
        - $PATH/templates:/var/www/html/templates:ro
        - $PATH/system/config/localconfig.php:/var/www/html/system/config/localconfig.php

      image: mariadb
      restart: always
      container_name: contao_db
        MYSQL_DATABASE: contao_database
        MYSQL_USER: contao_user
        MYSQL_PASSWORD: contao_password
        MYSQL_ROOT_PASSWORD: very_secret
        - $PATH/database:/var/lib/mysql

This will create 2 containers:

  • contao based on this image, all user-based files are mounted into the proper locations
  • contao_db a MariaDB to provide a MySQL server

To make Contao speak to the MariaDB server you need to configure the database connection in $PATH/system/config/localconfig.php just like:

$GLOBALS['TL_CONFIG']['dbDriver'] = 'MySQLi';
$GLOBALS['TL_CONFIG']['dbHost'] = 'contao_db';
$GLOBALS['TL_CONFIG']['dbUser'] = 'contao_user';
$GLOBALS['TL_CONFIG']['dbPass'] = 'contao_password';
$GLOBALS['TL_CONFIG']['dbDatabase'] = 'contao_database';
$GLOBALS['TL_CONFIG']['dbPconnect'] = false;
$GLOBALS['TL_CONFIG']['dbCharset'] = 'UTF8';
$GLOBALS['TL_CONFIG']['dbPort'] = 3306;
$GLOBALS['TL_CONFIG']['dbSocket'] = '';

Here, the database should be accessible at contao_db:3306, as it is setup in the compose file above.

If you're running contao with "Rewrite URLs" using an .htaccess you also need to update Apache's configuration to allow for rewrites. Thus, you may for example mount the follwoing file to /etc/apache2/sites-available/000-default.conf:

<VirtualHost *:80>
    ServerAdmin webmaster@localhost
    DocumentRoot /var/www/html
    <Directory /var/www/>
        AllowOverride All
        Options FollowSymLinks
    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined

This tells Apache to allow everything in any .htaccess file in /var/www.

Mail support

This image comes with sSMTP installed. If you need support for email with your Contao installation, you just need to mount two more files into the container:

Tell PHP to mail through sSMTP

The following file tells PHP to use the ssmtp binary for mailing. Just mount the file to /usr/local/etc/php/conf.d/mail.ini:

[mail function]
sendmail_path = "/usr/sbin/ssmtp -t"

Configure sSMTP

The sSMTP configuration is very easy. The following few lines may already be sufficient, when mounted to /etc/ssmtp/ssmtp.conf:


For more information read the documentation in my blog and the Arch Linux wiki on sSMTP or the Debian wiki on sSMTP.


Docker Image for Contao
Copyright (C) 2018 Martin Scharm <>

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <>.
Docker Pull Command
Source Repository