This Ansible playbook installs a self updating Pi-hole stack from scratch:
- You can choose between a Public Pi-hole or a Personal/Private one
- Both use unbound as recursive DNS server instead of public upstream DNS servers
- Both deploy (by default) the uber adlist/blocklist by OISD.nl
- Both add my (auto-updated) whitelist for your websurfing convenience
- If deploying a public Pi-hole, it includes LetsEncrypt to secure the admin interface with valid certificate over HTTPS
- If deploying a public Pi-hole, basic protection against DNS Amplification, SSH and bruteforce attacks is included using fail2ban
- The entire stack is based on Docker (so OpenVZ VPSes are NOT supported)
Tested on Ubuntu Server 18.04.2 LTS (Minimal) with Ansible 2.8 on Scaleway.com
I designed this playbook for my own personal usecase and decided to make it public for those of you who have the same usecase and/or want to (re)use specific parts from my playbook.
I'm willing to learn how to make this playbook more robust and generic. Therefore I am accepting pull requests :)
I highly recommend checking the playbook before running so that you know what will be installed etc.
- Please do not set up a PUBLIC Pi-hole if you don't know what you're doing. You risk getting in all sorts of trouble. Most ISPs don't allow a public DNS resolver on their networks and will shut you down without notice. Why? Because it's generally a bad idea. You have been warned.
- Make sure to add an A (and if applicable, AAAA) record for your Pi-hole's hostname in your domainname's DNS, pointing to the IP address of your server.
- If certificate generation fails, click here for troubleshooting steps
- Install Ansible
- Clone repository using
git clone https://github.com/Freekers/automated-pihole.git
- Edit
hosts
and.env
file to reflect your setup, i.e. change domains, IP etc.playbook.yml
does NOT need to be changed! - Install required roles from Ansible Galaxy roles using
ansible-galaxy install -r requirements.yml
- Start playbook using
ansible-playbook playbook.yml --ask-become-pass
When running the playbook on a remote target/server, make sure to copy your SSH key to remote target/server first (before running the playbook) usingssh-copy-id
Once everything has been installed, you can use regular docker and docker-compose commands to stop/start/restart containers.
The docker-compose.yml
file will be located at /opt/automated-pihole
after installation.
sudo docker-compose -f /opt/automated-pihole/docker-compose.yml down
rm -rf /opt/automated-pihole
- Consult playbook.yml to manually review packages & firewall rules that are no longer needed
- Even though this playbook configures and automatic updating Pi-hole, the Pi-Hole developers specifically have not included an auto-update option. It is best to read the release notes and determine if an update is appropriate for you, prior to updating. Sometimes updates can introduce breaking changes requiring manual intervention, such as editing/updating the docker-compose file. Therefore always keep an eye on the release notes.
- This playbook/script/repository is 100% unofficial and NOT affiliated with, funded, endorsed, or in any way associated with Pi-hole.
- Pi-hole Docker image by Pi-hole
- ouroboros Docker image by pyouroboros
- unbound Docker image by obi12341
- nginx-proxy Docker image by jwilder
- letsencrypt-nginx-proxy-companion Docker image by JrCs
- Unattended-Upgrades Role for Ansible by jnv
- Docker Role for Ansible by geerlingguy
- pihole-fail2ban by goncalopereira
- dbl.oisd.nl blocklist by sjhgvr
- Commonly white listed domains for Pi-Hole by anudeepND & Freekers
- Unbound configuration file for Pi-hole by Pi-hole
Unless otherwise specified, all code is released under the GNU General Public License v3.0. See the repository's LICENSE
file for details.
- Docker: Apache 2.0
- Ansible: GNU 3.0
- Pi-hole: EUPL 1.2
- ouroboros: MIT
- unbound: Apache 2.0
- nginx-proxy: MIT
- letsencrypt-nginx-proxy-companion: MIT
- Unattended-Upgrades: GPL 2.0
- Ansible Role - Docker: MIT
- whitelist: MIT