Blocky is a simple and lightweight DNS proxy for Linux-based home servers. Similar to Adguard Home and Pi-Hole, it works by redirecting DNS queries to an invalid address allowing you to control the websites and services available on your network.
Features
- Comes with pre-built filter for fast deployments
- Highly configurable blocklists with support for different groups
- Supports both legacy and modern DNS protocols
- Supports encrypted DNS by default
- Doesn’t rely on a database for storing data
- Resource-efficient and completely silent on normal use
Installation
The fastest way to install and deploy Blocky is by using Docker and Docker Compose. To do that, first create a folder for Blocky:
mkdir blocky
cd blocky
Create the configuration file for Blocky using your favorite text editor:
nano ./config.yml
Paste the following block of code inside it. This is the sample config template for Blocky that I modified to use both Cloudflare and Quad9 DNS servers:
upstreams:
groups:
default:
- 1.1.1.1
- 9.9.9.9
blocking:
denylists:
ads:
- https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts
clientGroupsBlock:
default:
- ads
ports:
dns: 53
http: 4000
Save the new config file, then create the docker-compose.yml for your Blocky instance:
nano ./docker-compose.yml
Paste the following block of code inside it:
services:
blocky:
image: spx01/blocky
container_name: blocky
restart: unless-stopped
hostname: blocky-fossery
ports:
- "53:53/tcp"
- "53:53/udp"
- "4000:4000/tcp"
environment:
- TZ=Asia/Manila
volumes:
- /etc/localtime:/etc/localtime:ro
- ./config.yml:/app/config.yml:ro
Make sure to replace the TZ variable with your appropriate timezone. In Ubuntu and other Systemd-based distros, you can find the available timezones by running ls /usr/share/zoneinfo
.
Save your docker-compose.yml file, then run the following command to install and run Blocky:
docker compose up -d
Usage
At this point, you now have a working Blocky setup. As a DNS server, it will forward any DNS request to either Cloudflare or Quad9 and it uses Steven Black’s famous blocklist for common ads and tracking services.
data:image/s3,"s3://crabby-images/fdd4e/fdd4e2c95322f6a39a366ae5549b9ec8ad366c99" alt="A screenshot of the Steven Black's popular ads and tracking blocklist."
Despite being incredibly simple to deploy, Blocky also comes with a ton of options if you want to customize your DNS server. For that, you can re-open the config.yml file using your favorite text editor.
data:image/s3,"s3://crabby-images/0aaf8/0aaf88fa88062e0d22bfcac44b919e2867e3defb" alt="A terminal showing default config file for Blocky."
Tweaking this file is as simple as adding or removing entries. For instance, you can insert a new DNS upstream by creating a new bullet point under the “upstreams:” category and adding its IP address.
data:image/s3,"s3://crabby-images/598c4/598c4a6254ec91ed7ff33d14e7636027bf000735" alt="A terminal showing the modified DNS upstreams."
This feature also extends to blocklists. While the default configuration already includes an extensive filter, you can also define your own or import from an external source. Just make sure to declare the file path in the “volumes:” section of your docker-compose.yml file if you decide to create your own blocklist.
data:image/s3,"s3://crabby-images/4aa68/4aa68e0aa39d3bc0dec0f7eef046326a9eeaeeea" alt="A terminal showing modified volumes: section in the docker-compose.yml file."
To top it off, Blocky also supports DNS-over-HTTP and DNS-over-TLS similar to AdGuard. This feature alone makes it an invaluable tool if you’re planning to run a private DNS server on the internet.
Once you’re done tweaking your Blocky instance, simply save your config.yml file, then run docker compose up -d
to rebuild and redeploy Blocky with your new settings.
data:image/s3,"s3://crabby-images/323a8/323a877ed5970ea27303aa8f9b45ae8b490e94ef" alt="A terminal showing the modified config.yml file for the Blocky instance."
Lastly, apply your new DNS server to your network by adding the IP address of the Blocky instance to either your PC or router’s DNS settings.
data:image/s3,"s3://crabby-images/44c34/44c34f907c43a6bf79a554845b6bb0c7c9d0ab53" alt="A screenshot showing the modified DNS server address on the Ubuntu client PC."
Final Thoughts
Blocky is a great terminal-based DNS proxy that’s flexible and easy to use. It’s quick to deploy, has great default settings, and offers advanced features such as DoH and DoT. Being CLI-only also means that Blocky doesn’t need a lot of resources to run. This makes it a great fit for low-end home servers and SoCs such as the Raspberry Pi.
Ultimately, Blocky is a highly versatile and feature-filled tool. I recommend it if you’re looking for a no-frills DNS server that can run on almost any architecture and OS platform. Having said that, Blocky isn’t the only DNS server solution available today. If you’re looking for a more user-friendly network-wide ad blocker, check out our brief review of the Pi-Hole.
Image credit: Blocky Github (Logo). All alterations and screenshots by Ramces Red.
Be the first to comment! Get the discussion going.