I’ve been using several services on my homelab, but I hadn’t sat down to
configure a DNS namespace for this network, so I was stuck trying to recall the
IPv4 address every single time. By the time I was done, I stopped accessing my
Jellyfin server with http://192.168.1.20:8096 and started using
http://media.home.arpa:8096
To begin, let’s list out my homelab infrastructure.
Infrastructure
Note on IP Addresses
The IP addresses shown throughout this post are anonymized. I’m not naive enough to publish my actual internal network addresses on the internet.
| Server | Type | IP | Services |
|---|---|---|---|
| Beelink EQI12 (Proxmox VE) |
VM | 192.168.1.1 | OpenWRT - Router, MultiWAN Failover |
| LXC Container | 192.168.1.2 | AdGuard Home + Unbound - DNS, Ad-blocking | |
| LXC Container | 192.168.1.20 | Media Server - Syncthing, Jellyfin, qBittorrent, Samba | |
| Host IP: 192.168.1.10 | |||
| Beelink EQR5 | Linux Mint | 192.168.1.50 | Dev Environment |
DNS Resolution Flow

Setting up a local DNS namespace
I have had these services setup for a few months now, but I haven’t setup a DNS namespace. So I’m still accessing my services with the IP addresses instead of easy-to-remember DNS names. Today, I wanted to fix that.
Unbound and Adguard are where my DNS lies, so I needed to figure out where to go
to add rules for this. I’m grateful for ChatGPT, because I used it to figure out
that I need to add a namespace file to /etc/unbound/unbound.conf.d/home.conf,
with rules for all these IPs. I first assumed that I’d be using media.local,
but I learnt that RFC 6762
reserves .local for mDNS, so that’s a no-go. Instead,
RFC 8375 designates
.home.arpa for home networks, which is exactly what I need. I like the sound
of that. I was today years old when I learnt that .arpa means “Address and
Routing Parameter Area”.
Here’s the Unbound configuration file I created at
/etc/unbound/unbound.conf.d/home.conf:
|
|
After creating this file, restart Unbound to apply the changes:
|
|
Now I can access my services using friendly names like eqr5.home.arpa or
media.home.arpa instead of remembering IP addresses.
Adguard Home Configuration
After restarting Unbound, I needed to go to the DNS settings page in Adguard
Home and update the upstream DNS settings to explicitly use 127.0.0.1:5335
(since unbound runs on the same host).

I also had to add this to the Private Reverse DNS providers section so that I could investigate what an IP is, if it’s registered and I’ve forgotten about it.

macOS Gotcha: DNS Needs Explicit Domain Routing
On macOS, simply having the DNS server set is not enough for custom internal
domains like home.arpa.
macOS uses domain-scoped DNS resolvers, so queries for home.arpa were never
sent to my AdGuard/Unbound server by default.
To fix this, I had to explicitly tell macOS to route that domain to my local DNS
server by creating /etc/resolver/home.arpa:
|
|
Then flush the DNS cache:
|
|
After this, ping and curl resolved *.home.arpa correctly.
Verifying the Setup
A quick dig confirms the forward lookup is working:
|
|
The NOERROR status and the ANSWER SECTION showing the correct IP confirms
that local DNS resolution is working.
Reverse lookup works well too.
|
|
Next Steps
To sum up, whenever I add a new server, I need to assign a static IP in OpenWRT,
then add it to the Unbound home.conf file, and restart Unbound. It’s a clunky
process, but I’m not adding devices every week, so it’s good enough.
I’d also like this working over WireGuard so I can access my services remotely, but for now, I’ve done what I set out to do: have friendly names for my services instead of IPs.