This repository contains what you need to get started self-hosting various services while also giving you a little knowledge around docker and docker-compose. The templates will set up the following:
- Base
- Pydio
- NextCloud
- Rocket.Chat
- Gucamole
- Bookstack
- Heimdall
- Mastodon (see also: Upgrading Mastodon)
- Airsonic
- ProjectSend
- Syncthing
- Draw.io
- MediaWiki
- Discourse
- Piwigo
- Gitlab¹
- Wallabag
- Transmission Bittorrent Client Webserver
- ytdl (Youtube Downloader)
- Riot.im (see also: Riot.im Setup)
To-dos
In no particular order, things I hope to add templates for. Also taking requests.
- Mailu
- OpenVPN
- Pinry
- ymarks
- Mozilla Firefox Sync
- Lobsters (link aggregation)
- Wordpress
- docker-mailserver
- RSS Monster
- Nunux Reader
- Nunux Keeper
- Apache OpenMeetings
- Cozy Cloud
- edX Platform
- Moodle
- Sakai
- Mahara
- OpenStreetMap
- HomeHost
- Friends Radio
- Volumio
- PeerTube
-
Pushjet(project seems to be inactive, homepage is unresponsive) - YouTransfer
- Onion Share
- Tag Spaces
- Flox
- Lychee
- Media Goblin
- Open Project
- Read the Docs
- Freedom Box
- FreeNAS
- OpenMediaVault
- WikiSuite
- Ghost
- Wekan
- Kanboard
- Tiny tiny RSS
- LibrePlan
- Hexo
- Searx
- Rainloop
- Known
- SoGo
- Taiga.io
- Logitech Media Server
- Moode
- A GUI to start and manage a stack created from these templates
You will need a computer, preferably running Linux, but anything will do. ² Download and install Docker and Docker-compose following the instructions for your OS
- Docker (or Docker Toolbox if you do not have Windows 10 Professional or Enterprise. See description below.)
- Docker-Compose
Please also, in a developer's text editor e.g. NotePad++, read through docker-compose.base.yaml as it contains detailed instructions in the form of comments. Before starting your stack, you will need to
- Register for DuckDNS and have your subdomain name and token ready
- Forwarded ports 80 and 443 through your router to your host machine
- Read through and get a basic understanding of the configuration options in every .yaml file you intend to use
- Copy template.env to .env with
cp template.env .env
and edit .env to contain your configuration WARNING: Never commit and push your changes to .env to a public git repository unless you want to get hacked!! You would basically be telling everyone where to find you and telling them your adminstrative passwords if you do! - Replace ALL placeholder values with your desired configuration following the model of the placeholder in ./configs/traefik.toml and any files in ./configs that are referenced in the docker-compose YAML files you intend to use. WARNING: Don't commit and push the changes you make to these files to a public git repository! See above!
- Made any other changes to the configuration of a service in a docker-compose .yaml file that you desire e.g. changing the domains to a custom domain that is not a subdomain of duckdns.org
- If your service utilizes email to send registration confirmations, forgotten passwords, user notifications, etc., you will either need to setup and a gmail account alias and use Google's SMTP server to send emails or use a custom domain with Mailgun, following their directions to verify your domain and then use their SMTP to send emails. Alternatively, you can also setup and use Mailu, but be aware spam email filters might think your domain is spammy because they won't recognize it. If you use Mailgun, you will need to upgrade from free to basic (which is still free if you're forwarding 10,000 emails or less per month) in order to be able to deliver to email addresses other than the one you registered with. You will need to enter a credit card to upgrade.
- If using Docker for Windows, you must comment out all Linux/Mac specific lines in all docker-compose .yaml files you intend to use and un-comment all Windows-specific lines. To help you spot them, I have used ### to designate comments in lines you will need to change.
- Docker for Windows requires Hyper-V, which is only available on Windows 10 Professional or Enterprise. Follow these instructions to enable Hyper-V. If you use Windows 10 Home, you will need to install and use Docker Toolbox to run your containers in a VirtualBox Virtual Machine instead. Both run your containers inside of a Linux Virtual Machine, which is not as lightweight as a container would be on Linux.
- Many if not most of these templates are written assuming you're running from a Linux environment. Attempts were made to make the templates compatible with windows, but there is no guarantee that they will work and you're probably better off using Linux, or at least a linux environment. You can emulate this in Windows using the Windows Subsystem for Linux. To control Docker for Windows from WSL, follow these instructions. Provided helper scripts will be written in Bash shell because that is what I know, therefore, they will only run in a Linux environment. Docker for windows has a Linux container mode, which runs the containers in a Linux virtual machine using Hyper-V, but this requires Hyper-V and Hyper-V requires a Windows 10 professional or enterprise license and is not available in Windows 10 Home.
At your system's command prompt, change directory to the base directory your local copy of this repository and run the following command:
docker-compose -f docker-compose.base.yaml config
This will check to make sure that the edits you made to any relevant .env files are valid. You can also do this later as you add more files to your stack with the -f option. (see below)
docker-compose -f docker-compose.base.yaml up -d
This will download the images for and start the base of your stack with basic services. To add additional services from this repository, add them to the command with additional -f flags e.g.
docker-compose -f docker-compose.base.yaml -f ./add-ons/docker-compose.NextCloud.yaml -f ./add-ons/docker-compose.RocketChat.yaml up -d
Please note: docker-compose.base.yaml must come first on this list. All the add-ons build upon this base. The order of the rest of the files does not matter.
The service "auto-updater" is included and can automatically update containers who have the label "com.centurylinklabs.watchtower.enable=true". If you would prefer to control when and to which version you update your containers to, or if the automatic updates are causing you issues taking services offline when they don't start up correctly (health checks have been included on most services to help mitigate this), you can disable the auto-updater on a per-service basis by setting the label "com.centurylinklabs.watchtower.enable=false" on that service. You can also update services using a scheduled cron job that runs the following commands:
#This will pull the latest image for each service specified in the -f included yaml files
docker-compose -f docker-compose.base.yaml -f ... pull
#This will recreate containers for any service whose image was updated in the previous command
docker-compose -f docker-compose.base.yaml -f ... up -d
#This will cleanup images which are no longer tagged i.e. a newer version of the image was pulled and the untagged image is not in use by any containers, even if the container itself is not running. -f here means "force" i.e. do not ask for confirmation before deleting the old image, just do it
docker image prune -f
To make a change to any service or container in your stack without bringing down and recreating them all, simply edit the docker-compose .yaml file that defines it, save, and re-run your docker-compose command from above. Docker-compose is inteligent enough to only recreate containers/services you edited in the file. You can also make changes using the edit functionality in the Portainer Docker GUI (included in the base .yaml file), however, it will not be able to automatically resolve if any dependant containers also need to be recreated.
If you want to bring everything down and remove all service/containers, Docker networks, and Docker volumes, simply run the following, specifying each docker-compose .yaml file you used to create it.
docker-compose -f docker-compose.base.yaml -f ... -f ... down
This will delete the entire stack, including data stored in Docker volumes, permanently. This will not affect volumes which are bind mounted to a container. Data in bind mounted volumes must be manually deleted.
Docker-compose can do more than just bring everything up or bring everything down. To manage your stack from the command line, pleaes refer to the Docker-compose CLI reference
- /r/HomeServer on Reddit
- /r/selfhosted on Reddit
- Awesome Self-hosted
- Awesome Sysadmin
- gLibre Services
- /r/Rad_Decentralization on Reddit
- /r/Privacy on Reddit
- /r/WebApps on Reddit
- /r/Docker on Reddit
- /r/DevOps on Reddit
Finally, please contact me if you find something wrong with any of these configs. My ability to test them 100% is limited and I don't use 100% of them myself, so these compose files are my best attempt based on reading the documentation for the app or container.
¹ Gitlab is extremely resource intensive and tends to leak memory over time. It probably won't run well on a Raspberry Pi and even on a traditional PC, I have had to schedule cron jobs that periodically restart it due to the memory leaks. Unsure if this is the result of misconfiguration on my part, or just how the software is. ↩
² The images used in these templates are mostly only built by their creators to run on x86_64 (Intel/AMD) processors. If you are a hoping to host one or more of these services on a Raspberry Pi or similar device and it doesn't run with the template as-written, open an issue to have the file or service adapted for use on ARM processors. ↩