Please check out my blog post for more information on this stack and how to use it.
I have created a basic docker stack for using Ghost, Matomo, MariaDB and Traefik for easyy deployment. The stack assumes you'll want everything behind HTTPS using Traefik's built-in Let's Encrypt functionality.
I created this stack as I couldn't find one already out there that was fully ready to go. I found ones that had part of this setup, but nothing that had all four of the key features I wanted; Ghost, Matomo, SSL and one shared DB.
There's definitely room for improvement with this project, but as it is right now it works as I want it to, and I want to share it now in hopes that it might help others as-well. I'll probably improve this a bit over time, and definitely welcome improvements from you, too.
This stack launches all the parts you need. Preparation-wise you only need to set the right environment variables. Please refer to example.env
, copy it as .env
and set it up for your own domain(s). When done, simply launch everything and you should be good to go. I highly recommend you read through the docker-compose.yml
file to get an idea for what's happening.
Both Ghost as-well as Matomo will use one database as specified in the DB_NAME
environment variable. While you could set up two databases, I choose to do one to make backups easier for me, and because both Ghost and Matomo support table name prefixes there will be no conflicts fortunately. If you prefer though, you can split out both into two separate databases by modifying the appropriate parts.
The first time you launch the stack, Ghost will likely have trouble connecting to the DB. This is because the first time MariaDB (or MySQL) launches, it needs a bit more time to prepare itself. Therefore I recommend you launch the entire stack without the -d
flag the first time, then stop it, and re-launch it proper. It should launch fine then.
To launch the entire stack, run the following command on your server that has Docker and docker-compose already installed, and has the domains you plan to use already pointing at it:
docker-compose up -d
If you made changes and need to relaunch your stack, run:
docker-compose down && docker-compose up -d
Generally I recommend you first run you stack without the -d
flag so you can easily read the boot logs and spot potential issues, then when all looks good just bring down the stack and bring it right back up, this time with the -d
flag.
All the DB connection settings have been prepared in the docker-compose.yml
file, so you can simply visit your blog at the domain you have set up and its admin panel at /ghost
to set up a user and get writing. Neato!
Matomo requires a bit of setting up, as its DB connection settings are stored in a php file. It is pretty straight-forward though, so just head on over to the (sub-)domain you set up for Matomo and follow its setup guide. When you get to the DB connection settings, be sure to choose mysql
as the database type, write db
as the database host name, and the username
, password
, and dbname
should be what you have specified in the DB_USER
, DB_PASSWORD
and DB_NAME
environment variables (in .env
).
Next, I recommend you set up Matomo to forcibly use SSL. In the same config.ini.php
file you can do this by adding force_ssl = 1
under the [General]
header. If this was not already set up after going through the Matomo setup, be sure to also add the domain names you're using for Matomo here by creating an array called trusted_hosts
. For example:
[General]
force_ssl = 1
trusted_hosts[] = "matomo.mydomain.com"
; everything else
Here's a brief summary of files and directories to be aware of:
This repository comes with a php.ini
file with some settings already prepared to make Matomo work well. You can add your own settings here if needed, but note that this file is only used for Matomo.
Traefik will, upon successfully fetching and setting up SSL certificates, automatically create a file called acme.json
that contains this information. While you should probably never edit this file directly yourself, it is stored here to preserve it even if you destroy your docker images or move to another server.
Matomo's configuration files can be found here after you have successfully launched the stack at least once. You can place your existing config.ini.php
file here, or modify the one generated by Matomo after following its setup process.
Ghost's content
folder is linked to here, and will be where you can find your blog's actual content, images uploaded, themes, et cetera. This is the folder you'll want to backup, for example.
I hope this stack might help someone else in setting up their (personal) blog with self-hosted analytics. This way you can quickly get started, have SSL out of the box, and use Matomo's great analytics features to better understand who or what visits your site, without shipping off boatloads of personal data to some other company. I would love to hear your thoughts on this stack and if you have improvements, I very much appreciate enhancements. Sharing is caring!