Gudgeon
Overview
Gudgeon is a caching/blocking DNS proxy server. What sets Gudgeon appart is the ability to segregate machines, subnets, and IP ranges into different groups that all receive different blocking rules. The motivation for Gudgeon comes from the proliferation of devices on my home network that belong either to outside entities (Google, AT&T, Amazon), kids, or unwise adults. Different groups need different blocking rules.
Take, for example, a user who has shown persistent inability to avoid internet scams. You can assign that user's machine(s) to group(s) that block more suspicious DNS requests. On the other hand you might want to allow a device like a Google Home or Alexa unit to have full access to the internet except for tracking/advert websites. You might want to create extensive blocklists to protect kids who use the internet from their devices.
For all of these reasons Gudgeon has been created to allow more flexibility in host-based DNS blocking.
Features
- Go Routines for non-blocking request handling enables high-througput especially with simultaneous requests
- Systemd Integration to run as non-root user (with access to priveleged ports through Systemd sockets)
- Configure upstream DNS types (tcp-tls/dns-over-tls, tcp, and udp) explicitly
- Using regular expressions and wildcards to block DNS names
- Matching an address (or subnet, or subnet range) to a user and determining what blocklists to use
- Resolvers and resolver groups for certain/specific subnets based on matching incoming connections
- Inline host file entries in configuration file as well as external host files
- Enhanced (and backwards-compatible) hostname format supports wildcard names, CNAME/PTR entries, and reverse lookups
How Do I Install Gudgeon?
There are a few different ways to install Gudgeon that don't require you to build it yourself. Gudgeon aims to support recent of releases Debian, Ubuntu, RHEL/CentOS, and Fedora as well as Docker and direct MIPS builds.
GitHub Releases
New tagged releases are automatically built by Travis-CI and uploaded to GitHub for download. Functionally these releases are identical to releases available in other channels. You can find these releases here.
Fedora Releases
Gudgeon has a COPR repository for Fedora 28, 29, and CentOS 7.
#optional, may be required for CentOS/EL linux
[user@host] yum install yum-plugin-copr
# enable COPR and install gudgeon, use appropriate yum commands on non-dnf platforms
[user@host] sudo dnf copr enable cruffalo/gudgeon
[user@host] sudo dnf install -y gudgeon
Docker Releases
Gudgeon also comes in container form from gudgeon/gudgeon
.
The Docker container exposes ports 5354 (dns) and 9009 (http) and those ports should be published via the docker
command. Remember to use /tcp
and /udp
when exposing the ports. For persisting/modifying the configuration and for persisting data, metrics, and logs there are two directories in the container. The first directory /etc/gudgeon
is for configuration files. The data is stored in /var/lib/gudgeon
. The version can be any tag v0.3.12 or later. See the docker hub page for tags and more details.
[user@host] docker run -ti -p 53:5354/tcp -p 53:5354/udp -p 9009:9009 -v /etc/gudgeon:/etc/gudgeon -v /var/lib/gudgeon:/var/lib/gudgeon gudgeon/gudgeon:${version}
What About Dnsmasq and Pi-Hole?
Many people reading this are going to point to Pi-Hole or at least Dnsmasq. Those projects are absolutely excellent and they are really inspirations to me as I work on Gudgeon. However, there are a few reasons why these projects are not sufficient for what I am trying to accomplish. I should also note that most people don't want what Gudgeon does and, frankly, that's pretty expected. There are also people who need the extra features provided by Pi-Hole or Dnsmasq and that's fine too.
The first reason is what always comes up with Open Source Software: I wanted to do it myself. I have some small experience with DNS manipulation in Go and I really enjoyed it so I wanted to do something with a little more complexity.
The other reason is that neither of those solutions will have the right feature set for me without a significant amount of tweaking. A lot of sources say to either use firewall rules and run two instances of your DNS server or to configure each potential client individually. I feel like this is the point I came to and decided to actually do something about it because I really didn't want to run two DNS servers or manage configuration that way... so I spent hours writing a DNS proxy instead.
Pi-hole and Dnsmasq also provide a lot more DNS features than Gudgeon ever will. Gudgeon aims to focus on the classification of consumers and what to allow, block, or redirect based on that classification. It does not aim to provide a completely comprehensive DNS proxy or more than a small subset of DNS features.
Finally I wanted to build something that is a little more self-contained and easier to deploy. Gudgeon is a small container-based solution or a single deployable binary with minimal configuration required.
Building
Prerequisites
- Ability to use Makefiles (
make
command installed)
- Go > 1.11 (module support is required)
upx
(for binary compression)
fpm
(for building deb/rpm)
- Docker (for building docker images or xgo support)
With the prerequisites installed you can build Gudgeon by...
- Preparing your environment with needed Go tools with
[]$ make prepare
- Downloading vendor assets (patternfly, vue, etc) with
[]$ make download
- Building the binary with
[]$ make
The download
target is used to download new dependencies when needed. The prepare
target is only needed if the required Go tools change. The output of the process is a statically compiled for a few different platforms. The binary is statically compiled to make it easily portable to platforms and other systems that do not have libc, recent Golang compilers, or other required libraries.