Skip to content

Local DNS based ad (etc) blocker, privacy enhancer, and performance optimizer, partially inspired by Pi-hole.

License

Notifications You must be signed in to change notification settings

lietu/better-dns

Repository files navigation

Travis-CI build status License

Better DNS

Local DNS based ad (etc) blocker, privacy enhancer, and performance optimizer, partially inspired by Pi-hole.

Better DNS in action

What it can do:

  • Supports DNS over TLS and DNS over HTTPS (using the DNS UDP wire protocol) servers with e.g. Cloudflare to avoid snooping, as well as plain old insecure DNS (but why would you want to use it?)
  • Run locally, no need to host servers of any kind, but you can also run it on a server
  • Protect you in every network you're connected to
  • Block (many) ads (and other unwanted things) in pretty much all programs you use (unless they use some custom DNS setup, which is not very common)
  • Parse common block lists from HTTP(S) urls (/etc/hosts format, and one host per line)
  • Support a custom blacklist as well with * wildcard support
  • Block A & AAAA record resolution of addresses on those lists
  • Performs DNS requests to multiple servers in parallel and returns fastest successful response
  • Proxy any non-blacklisted DNS requests to a proper DNS server
  • Caches results (minimum 30s, otherwise respects TTL in responses, using a fixed-size LRU) - leads to a minor performance enhancement in some scenarios
  • Override your active DNS servers while it's running and return them to normal on exit
  • Show all the DNS requests your software is doing (if you increase log level to debug) - maybe you'll find it enlightening
  • Supports Windows, Mac, and Linux (at least based on limited testing)

Current version is quite preliminary still, however it seems to very much work (on Windows 10, Mac OS High Sierra, and Fedora 31 armhfp on Raspberry Pi 2).

You probably have to run it as Administrator/root so it has enough permissions to edit your DNS server configuration and listen to port 53 TCP & UDP, as these are privileged service ports.

Quick installation on Raspberry Pi

The install.sh script can be used to quickly configure Better DNS as a server on e.g. a Raspberry Pi device running in your network. It's never a good idea to just run scripts off the internet on your machine without checking them first, so do that first, then run this:

curl -L https://raw.githubusercontent.com/lietu/better-dns/master/install.sh | sudo bash -

It will:

  • Download and install better-dns to /usr/sbin/better-dns
  • Set up the default configuration to /etc/better-dns.yaml
  • Installs a service to run /usr/sbin/better-dns -config /etc/better-dns.yaml at boot and starts it

Afterwards you only need to configure your router's DHCP settings or manually configure your computers to use the Raspberry Pi for DNS. You can also tweak /etc/better-dns.yaml to your liking and then restart the service (e.g. systemctl restart better-dns.service).

Recovery in case of errors

This is still early software and it's possible not all the kinks have yet been worked out. It is possible that you encounter a crash and the software will not automatically recover your DNS settings.

There are some fairly universal solutions to that, if you end up with a broken network connection:

  1. Reconnect to your network (toggle Wi-Fi off & on, reconnect ethernet cable, or similar)
  2. Restart the app (should temporarily fix it, though will likely fail to block anything)
  3. Restart your computer (ew, but works)

Alternatively you can run these commands to fix it:

Windows:

In Administrator PowerShell:

Get-DnsClientServerAddress  # Check the InterfaceAlias column for names of related interfaces
SetDnsClientServerAddress -InterfaceAlias "<interface name>" -ResetServerAddresses

macOS:

These might require sudo:

# To list the network interfaces, look for "Hardware Port" -lines
networksetup -listallhardwareports
# To reset their DNS settings
networksetup -setdnsservers "<hardware port>" empty

Linux:

Replace /etc/resolv.conf with /etc/resolv.conf.better-dns-tmp, e.g.:

sudo mv -f /etc/resolv.conf.better-dns-tmp /etc/resolv.conf
# or
cat /etc/resolv.conf.better-dns-tmp | sudo tee /etc/resolv.conf 

Configuration

The better-dns.yaml has an example configuration. It's expected to be found at ~/.config/better-dns/better-dns.yaml, %APPDATA%\better-dns\better-dns.yaml, ~/Library/Application Support/better-dns/better-dns.yaml, or in a file defined by -config <path> -argument to better-dns.

DNS Servers

By default better-dns uses one Cloudflare server with DNS over HTTPS, and one with DNS over TLS, but you may want to customize the servers. Entries should be URIs, with https://ip/url, dns+tls://ip, or dns://ip -format, e.g.:

dns_servers:
  - https://1.1.1.1/dns-query
  - dns+tls://1.0.0.1
  - dns://192.168.1.1

Block lists

There are a number of default blocklists defined that should be a good basis to start from. If you want to choose your own lists to use, you can define them in a simple list of URLs to use.

Files in the /etc/hosts format, as well as simple lists of one host per line, are supported. Lines starting with # are ignored.

block_lists:
 - https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts
 - https://mirror1.malwaredomains.com/files/justdomains
 - http://sysctl.org/cameleon/hosts
 - https://s3.amazonaws.com/lists.disconnect.me/simple_tracking.txt
 - https://s3.amazonaws.com/lists.disconnect.me/simple_ad.txt
 - https://hosts-file.net/ad_servers.txt
 - https://pgl.yoyo.org/adservers/serverlist.php?hostformat=hosts&showintro=0&mimetype=plaintext

Blacklist

In case you want to add custom entries to block, with simple * wildcard support, that's also supported. The default is to block wpad.* requests (Web Proxy Auto-Discovery Protocol) for a minor speedup, but you can remove that or add various entries like this:

blacklist: []
# OR
blacklist:
 - my.blacklist.domain
 - "*.wildcard.domain"
 - "prefix.*"

Listen address

By default better-dns only listens to 127.0.0.1, but if you want to listen to other interfaces you can set it to listen to a specific interface IP or 0.0.0.0 for all interfaces:

listen_host: 0.0.0.0

Better DNS Manager

The better-dns-tray[.exe] executable is an experimental attempt to provide a minimal GUI tool to run better-dns. It will still require Administrator privileges, and it's likely got some significant bugs. Try at your own peril.

Better DNS manager UI

Future ideas

  • Running as a service
  • Installers or similar
  • Support for more OSes (should be pretty easy to add, would like to see BSDs at least supported in the near future, and specifically router software like pfSense supported)
  • Cached block lists in case your network isn't working perfectly when you launch the software
  • Periodically checking the lists for updates (e.g. hourly / daily)
  • Monitor for new networks (e.g. WiFi) and update their DNS settings as well
  • Reporting interface similar to Pi-hole (but probably not as detailed due to privacy issues)

License

Short answer: This software is licensed with the BSD 3-clause -license.

Long answer: The license for this software is in LICENSE.md, the libraries used may have varying other licenses that you need to be separately aware of.

(Original) Icon made by Vectors Market from www.flaticon.com

Financial support

This project has been made possible thanks to Cocreators and Lietu. You can help us continue our open source work by supporting us on Buy me a coffee.

"Buy Me A Coffee"

About

Local DNS based ad (etc) blocker, privacy enhancer, and performance optimizer, partially inspired by Pi-hole.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages