Skip to content

A DNS Proxy Server powered by dnsdist with automatic TLS cert management

License

Notifications You must be signed in to change notification settings

ragibkl/dnsdist-acme

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2947a83 · Sep 13, 2024

History

66 Commits
Mar 10, 2024
Dec 31, 2023
Dec 30, 2023
Dec 31, 2023
Sep 13, 2024
Dec 30, 2023
Aug 21, 2024
Aug 26, 2024
Aug 26, 2024
Aug 26, 2024
Jan 2, 2024
Jan 2, 2024
Dec 31, 2023
Aug 26, 2024
Dec 31, 2023

Repository files navigation

dnsdist-acme

A DNS Proxy Server powered by dnsdist with automatic TLS cert management

Introduction

dnsdist is a highly DNS-, DoS- and abuse-aware loadbalancer. Its goal in life is to route traffic to the best server, delivering top performance to legitimate users while shunting or blocking abusive traffic.

In order to make it easier to deploy onto a live environment and easier to debug, I decided to combine dnsdist with several components:

  • dnsdist - dns load balancer. The current config enables handling DNS53, DoT, DoH protocols
  • certbot - automatically handles obtaining an TLS cert from LetsEncrypt, for use in DoT and DoH protocols
  • golang-dnstap - captures query logs from dnsdist and saves it to a file
  • [rust] - main binary to orchestrate the different components. Also serves a web page for viewing the dns logs from the origin ip address

At the moment, this project is available as a Docker container, with all the required components built-in. It is currently only available for Docker architecture linux-x86_64. If you want to run this on a Raspberry PI, I will need to build and push this project Docker images for Armv6 and Armv7 architectures. I intend to provide this in the near future.

This project is currently used in my Adblock DNS Server to serve as the DNS ingress point. It handles the incoming DNS53, DoT, DoH traffic and routes it to the main Bancuh Adblock DNS.

Getting Started

The simplest way to see it in action is to run it using a Docker Compose file. This example spins up the dns proxy and routes all traffic to Google's DNS at 8.8.8.8. Run it with docker compose up -d.

version: "3"

services:
  dnsdist:
    image: ragibkl/dnsdist-acme
    restart: always
    environment:
      - PORT=53
      - BACKEND=8.8.8.8:53
      - TLS_ENABLED=false
      - TLS_DOMAIN=dns.yourdomain.com
      - [email protected]
    network_mode: host

Enabling DoH and DoT protocols

In order to enable DoH and DoT protocols, you need to run this project on a server with a public IP address. Additionally, you also need to have a FQDN domain record that resolves to the IP address of your server. Probably something in the form of dns.yourdomain.com

Update the following variables and rerun docker compose up -d

- TLS_ENABLED=true
- TLS_DOMAIN=dns.yourdomain.com # Put your fqdn here
- [email protected]    # Put a valid email here

With tls enabled, the server will obtain a TLS cert from LetsEncrypt, keep it updated, and use it to serve DNS traffic over DoH and DoT.

Viewing Logs for Troubleshooting

A feature of this project is the ability to view DNS query logs for the originating IP. Logs are cleaned up every 10 minutes.

Logs pages:

Using it with other DNS projects

This dns project should be used in conjuction with another DNS service. You can follow the instructions at Adblock DNS Server - Getting Started to see how it can be used with my Bancuh Adblock DNS project.

In theory, you should be able to use it together with other Adblock DNS server such as PiHole. The following example has not been tested, but you should be able to tinker it to work.

version: "3"

# Minimal setup. More info at https://github.com/pi-hole/docker-pi-hole/ and https://docs.pi-hole.net/
services:
  pihole:
    image: pihole/pihole:latest
    ports:
      - "1153:53/tcp" # using a different port
      - "1153:53/udp"
    environment:
      TZ: 'America/Chicago'
    volumes:
      - './etc-pihole:/etc/pihole'
      - './etc-dnsmasq.d:/etc/dnsmasq.d'
    restart: unless-stopped

  dnsdist:
    image: ragibkl/dnsdist-acme
    restart: always
    environment:
      - PORT=53
      - BACKEND=127.0.0.1:1153 # point to pihole backend
      - TLS_ENABLED=false
      - TLS_DOMAIN=dns.example.com
      - [email protected]
    network_mode: host

About

A DNS Proxy Server powered by dnsdist with automatic TLS cert management

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published