Piwik is a popular open source web analytics platform.
This Docker container strives to be a production-ready flexible solution to use Piwik connected to your choice of MySQL database. It features nginx and PHP-FPM, and is built on top of the baseimage-docker container from Phusion.
First, rename docker-compose-template.yml file :
mv docker-compose-template.yml docker-compose.yml
Then edit it to match your preferences.
Once done, build the containers : docker-compose build
or alternatively build&run it : docker-compose up
docker build -t piwik .
First, run the MySQL container : docker run -d --name=piwik-mysql -e MYSQL_USER=piwik -e MYSQL_PASSWORD=piwik -e MYSQL_ROOT_PASSWORD=piwik -e MYSQL_DATABASE=piwik -v /srv/piwik-mysql:/var/lib/mysql mysql
Then run the Piwik container : docker run -d --name=piwik --link piwik-mysql:db -p 8080:80 -p 8443:443 -e PIWIK_SEED_DATABASE=true -e PIWIK_USER=admin -e PIWIK_PASSWORD=password piwik
docker build -t piwik .
Run the Piwik container : docker run -d --name=piwik --link piwik-mysql:db -p 8080:80 -p 8443:443 -e PIWIK_SEED_DATABASE=true -e PIWIK_USER=admin -e PIWIK_PASSWORD=password piwik
Piwik connects to a MySQL database. You have your choice of running that in a separate container alongside the Piwik container on the same Docker host, running it on an entirely separate server, or even using a hosted MySQL solution (such as Amazon RDS). All of this information is passed along to the Piwik container in environment variables at container creation time, and the environment variables are listed below.
DB_HOST
Set DB_HOST
to the IP address or domain name of the MySQL database you would like to connect to. Alternatively, link the Piwik to a MySQL container with the name db_1
.
DB_PORT
Optionally, set DB_PORT
to the port on which your MySQL database is listening. Alternatively, link the Piwik container to a MySQL container with the name db_1
.
DB_USER
Set DB_USER
to the MySQL user that Piwik will use. This does not need to be a superuser, but it does need to have all permissions on the database specified by DB_NAME
.
DB_PASSWORD
Set DB_PASSWORD
to the MySQL password that corresponds with DB_USER
.
DB_NAME
Set this to the MySQL database name that Piwik will use. This database should already exist, and DB_USER
should have all permissions for it.
DB_TABLES_PREFIX
Optionally, set DB_TABLES_PREFIX
to whatever you would like Piwik to prefix its table names with. Default is piwik_
.
DB_CHARSET
Optionally, set the character set that should be used for the MySQL tables. Default is utf8
.
PIWIK_SEED_DATABASE
Optionally, set PIWIK_SEED_DATABASE
to true
if this is a fresh install to a new database. The database schema and a sample site will be loaded into the database.
PIWIK_USER
Set PIWIK_USER
to the administrator username you want to use for Piwik.
PIWIK_PASSWORD
Set PIWIK_PASSWORD
to the admininistrator account password you want to use.
Piwik is an internationally registered trademark, and copyright and license information is available here: https://github.com/piwik/piwik/blob/master/LEGALNOTICE
This container also includes GeoLite data created by MaxMind, available from http://www.maxmind.com.