Piwik is a rich open-source web analytics platform, which can be coupled with commercial plugins for additional features. It's most simply described as "self-hosted Google Analytics".
Limitation of docker-swarm¶
The docker-swarm load-balancer is a problem for deploying piwik, since it rewrites the source address of every incoming packet to whichever docker node received the packet into the swarm. Which is a PITA for analytics, since the original source IP of the request is obscured.
The issue is tracked at #25526, and there is a workaround, but it requires running the piwik "app" container on every swarm node...
Create piwik.env, and populate with the following variables
Setup docker swarm¶
Create a docker swarm config file in docker-compose syntax (v3), something like this:
I share (with my sponsors) a private "premix" git repository, which includes necessary docker-compose and env files for all published recipes. This means that sponsors can launch any recipe with just a
git pull and a
docker stack deploy 👍
version: '3' services: db: image: mysql volumes: - /var/data/piwik/mysql/runtime:/var/lib/mysql env_file: /var/data/config/piwik/piwik.env networks: - internal app: image: piwik:apache volumes: - /var/data/piwik/config:/var/www/html/config networks: - internal - traefik deploy: mode: global labels: - traefik.frontend.rule=Host:piwik.example.com - traefik.docker.network=traefik - traefik.port=80 cron: image: piwik:apache volumes: - /var/data/piwik/config:/var/www/html/config entrypoint: | bash -c 'bash -s <<EOF trap "break;exit" SIGHUP SIGINT SIGTERM while /bin/true; do su -s "/bin/bash" -c "/usr/local/bin/php /var/www/html/console core:archive" www-data sleep 3600 done EOF' networks: - internal networks: traefik: external: true internal: driver: overlay ipam: config: - subnet: 172.16.4.0/24
Setup unique static subnets for every stack you deploy. This avoids IP/gateway conflicts which can otherwise occur when you're creating/removing stacks a lot. See my list here.
Launch the Piwik stack by running
docker stack deploy piwik -c <path -to-docker-compose.yml>
Log into your new instance at https://YOUR-FQDN, and follow the wizard to complete the setup.
Tip your waiter (sponsor me) 👏¶
Did you receive excellent service? Want to make your waiter happy? (..and support development of current and future recipes!) Sponsor me on Github / Patreon, or see the support page for more (free or paid) ways to say thank you! 👏
Flirt with waiter (subscribe) 💌¶
Want to know now when this recipe gets updated, or when future recipes are added? Subscribe to the RSS feed, or leave your email address below, and we'll keep you updated. (*double-opt-in, no monkey business, no spam)