this post was submitted on 05 Oct 2024
34 points (94.7% liked)

homelab

6714 readers
6 users here now

founded 4 years ago
MODERATORS
 

Hey there, im looking into setting up a DNS Server in my Homelab, i would like something like this:

  1. Server in Docker on my Proxmox Server
  2. Server in Docker on my NAS and
  3. Server in my "Cloud" Network

Do you guys have any recommendations on how i could accomplish this? Otherwise i will just use PiHole with sync again or something like it :)

all 30 comments
sorted by: hot top controversial new old
[–] JoeKrogan@lemmy.world 10 points 2 months ago

Adguard home

[–] OR3X@lemm.ee 6 points 2 months ago (1 children)

Two PiHole servers. One is hosted via docker on my primary file server and the other is hosted in a Hyper-V VM on my sole windows box. The VM one is also my DHCP server.

[–] Kage@discuss.tchncs.de 1 points 2 months ago

I had this setup a couple of months ago, worked great with gravity-sync :)

[–] leverage@lemdro.id 6 points 2 months ago (1 children)

Unbound on my OPNsense firewall. I don't have advice for you, do you have some specific goals besides just having a DNS?

[–] Kage@discuss.tchncs.de 1 points 2 months ago (1 children)

Not really, just fed up with remembering IP-Adresses :)

[–] leverage@lemdro.id 2 points 2 months ago

Look at reverse proxy instead. While you can do what you're after with DNS, a bunch of the reverse proxy systems will automatically deal with SSL certificate, and there are even a couple that eliminate essentially all configuration outside of your docker file. Like, add a new docker and it automatically configures appName.domain.tld with SSL assigned. And if you ever decide to expose that address to the Internet, reverse proxy makes that simple and provides some security options as well.

I use Caddy for my reverse proxy running from my OPNsense firewall, but if you want the automation with docker there are better options.

[–] Penguincoder@beehaw.org 5 points 2 months ago (1 children)
[–] Kage@discuss.tchncs.de 3 points 2 months ago (1 children)

I will give this one a try, had a eye on it before asking already :D

[–] arcayne 3 points 2 months ago

Solid choice. It's been my go-to DNS+DHCP solution for over 5 years and has never let me down. Also a fan of DNSDist+PowerDNS, but for most environments (especially home/lab), Technitium wins by a mile.

[–] ReversalHatchery@beehaw.org 5 points 2 months ago (1 children)

I use pihole for its good filtering, selective filtering, statistics and logging capabilities, and technitium dns as its upstream for it's superior capability in defining dns records, and because I can use a DoH dns provider with it

[–] LeTak@lemm.ee 4 points 2 months ago

Two Pi-Hole docker container on two different servers. OpnSense DNS Plugin. Fallback, NextDNS Alternative, AdGuard is also a good DNS.

[–] surfrock66@lemmy.world 4 points 2 months ago* (last edited 2 months ago)

I have a philosophy of sticking close to reference implementations and upstream in the homelab because it forces me to learn principles rather than implementations. I use bind9, but that upstreams to pihole on a different port. It is hard to configure for sure, editing zone files in vi, but I learn a lot analyzing the reference syntax to understand features. I also use isc-dhcp-server for DHCP, again manually populating dhcpd.conf.

Bind can peer with other instances; right now it is it's own ipam vm on my proxmox with bind/isc-dhcp/pihole docker, but I'm looking at dropping some hardware at a family member's for a site 2.

[–] gungho4bungholes@lemmy.world 4 points 2 months ago
[–] Omripresent@lemmy.ml 4 points 2 months ago

I have a total of 4 (for now) DNS servers, 2 within the lab (AlmaLinux on Proxmox), 1 running on OpnSense and 1 on a VPS (AlmaLinux). All are running Unbound + dnscrypt-proxy for external resolution, the AlmaLinux ones also have unbound-exporter for telemetry.

The pair in the lab also run Keepalived with 2 VIPs for active/active setup (VIP 1 active/backup for DNS1/2, VIP2 active/backup for DNS2/1). All servers target the VIP addresses for resolution with options timeout:1 attempts:3 rotate in the /etc/resolve.conf file.

For internal DNS records I run FreeIPA (as well for server/ldap auth) with zone transfers to all Unbound instances, this way there's no dependency on FreeIPA and the lab to be online for DNS resolution of internal records and it prevents the need for forwarding those queries to FreeIPA.

All instances also have a scheduled service to download and apply a blocklist from https://github.com/StevenBlack/hosts

I would like to look into Unbound views for the OpnSense instance to be able to resolve different records if the source it IOT/Untrusted zone vs LAN/Trusted zone, for now I have BIND tied to specific IPs used by IOT/Untrusted exclusively without access to resolve the lab zones.

[–] AlternateRoute@lemmy.ca 4 points 2 months ago (1 children)

I run Unbound on my opnsense firewall.

[–] Kage@discuss.tchncs.de 2 points 2 months ago

I think i will try unbound too :) Thank you!

[–] dotslashme@infosec.pub 3 points 2 months ago

I use Blocky as my DNS server.

[–] biscuitswalrus@aussie.zone 3 points 2 months ago (1 children)

Two pihole servers, one n VM vlan, one on device VLAN with OpnSense delivering them both via DHCP options. I sometimes update lists, like yearly... At best. They've been there over 7 years. Calling them robust is correct. The hypervisors are 3 proxmox servers in cluster using ceph. Intrl NUC 3rd Gen. Less than 80w combined with all vms. Also 8 years old no failures but tolerant for it.

[–] ReversalHatchery@beehaw.org 3 points 2 months ago* (last edited 2 months ago) (2 children)

I sometimes update lists, like yearly... At best

Don't they get updated automatically?

[–] biscuitswalrus@aussie.zone 1 points 2 months ago

Iirc I seem to find whatever was configured dead or no longer the cool choice when I check online.

Whatever it is, I barely touch it and it works great. Very happy.

[–] Kage@discuss.tchncs.de 1 points 2 months ago

I think you can configure them to do so :)

[–] con_fig@programming.dev 3 points 2 months ago

My home lab is small so I just run BIND ony server

[–] Coelacanthus@lemmy.kde.social 2 points 2 months ago

Just run it as systemd service on my server.

[–] apt_install_coffee@lemmy.ml 2 points 2 months ago* (last edited 2 months ago)

I use PiHole+Unbound in a podman quadlet, and give it its own macvlan. Works great for me.

[–] conrad82@lemmy.world 2 points 2 months ago

I'm using leng in an dedicated LXC container in Proxmox

https://github.com/cottand/leng

I'm using defaults + some local dns lookups. Works fine for my use, and lighter than pihole. No web ui

[–] MangoPenguin@lemmy.blahaj.zone 2 points 2 months ago

The default Unbound server on Opnsense.

[–] BlueEther@no.lastname.nz 2 points 2 months ago

I use AdGuard in my OpnSense firewall.

Why do you want a server on proxmox and NAS? or have I read this wrong?

[–] oh_gosh_its_osh@lemmy.ml 1 points 2 months ago

CoreDNS in Docker to mix things up here a little.