Today, you’ll install a new service on your Raspberry Pi: a DNS server
It’ll help you to speed up your web browsing, secure your requests and teach you a few things about how DNS is working
How to use your Raspberry Pi as a DNS Server?
There are several options, but today I’ll keep it simple and install DNSMasq.
DNSMasq is a service you can add on your Raspberry Pi to answer DNS requests.
After this, you just need to update your computer settings to use the Raspberry Pi as the DNS server.
Let’s do it!
I will start with a quick reminder about DNS theory and after that we’ll install it on your Raspberry Pi
A quick DNS reminder
If you’re here, you probably know the basics about DNS services
But it’s a good thing to check this paragraph to make sure you understand everything during the installation process
What is DNS?
DNS stands for Domain Name System
It’s a main service on the Internet.
Its role is to translate domain names into IP addresses.
On a network, devices only speak with IP addresses, and they need a DNS server to help convert host name to IP.
For example, a DNS request could be:
- Your computer: What’s the IP address of raspberrytips.com?
- The DNS server: You can use 184.108.40.206
This kind of request happens every time on a network with Internet access
How it works?
Your DNS server is a member of a hierarchy
When you send a request there are two options:
- The server knows the answer: you get the IP address directly
- The server doesn’t know the corresponding IP address: the server sends the same request to its own DNS server and send you back the answer
If its own DNS server doesn’t have the answer either, it will ask the upper server, etc…
In this schema, your Raspberry Pi will be at the bottom of the tree, and each circle is another DNS server
We call the node at the top a root server, and it has the answer for any requests with an existing domain name
Each request starts at the bottom and climb the tree each time a DNS server doesn’t have the answer
Why do you need to install a DNS server in your local network?
There are four reasons why you need a DNS server inside your network:
- Speed up your Internet browsing: On the tree above, each time the request go into the next DNS server, there is an additional time to wait. With a DNS server on your network, using a caching system, most of the requests can be answered directly.
- Keep your browsing safe: When you use your provider DNS servers, or the Google ones, you are allowing them to know any website you visit on the Internet. By keeping the control on the DNS service, you keep this private (most of the time)
- Stability: Even by using well known DNS servers, you can lose your Internet connection if the servers you are using are down or too slow. By having DNS servers on your network, you also keep the control on this.
- Custom records: With a DNS server at home you can create your records in the DNS server. For example, if I want to redirect kodi.me.local to my media center Raspberry Pi it’s possible.
There are probably other advantages, and maybe some cons
But if you are a Linux expert, you can manage this easily 🙂
Install a DNS server on Raspberry Pi
The software choice
The first thing to do is to choose the software you’ll use for your DNS service
I already gave you my choice, but basically, you have to choose between:
- Bind: the most used DNS service on Linux, but complicated to set up
- DNSMasq: a lightweight and easy-to-use DNS server
So, for this project, you will probably use your Raspberry Pi at home in a small network.
DNSMasq is the best option, it will not take many resources and will be easy to configure.
I already wrote an entire article about how to install Raspbian on Raspberry Pi, so I won’t repeat this here. Click on the link to read the step-by-step tutorial.
Raspbian Lite will be perfect for this, enable the network, SSH, and move to the next paragraph.
Install DNSMasq on your Raspberry Pi
The DNSMasq installation process is straightforward:
- Connect to your Raspberry Pi via SSH (or type directly the following commands on it)
- Update your system
sudo apt update sudo apt upgrade
- Install the DNSMasq package
sudo apt install dnsmasq
That’s it, DNSMasq is now installed
The DNSMasq configuration file is /etc/dnsmasq.conf.
I will show you a basic configuration, but each setting is well commented, so you can find easily which one to use.
- Open the configuration file with nano
sudo nano /etc/dnsmasq.conf
- Comment out these three lines:
domain-needed bogus-priv expand-hosts
The “domain-needed” line allows sending DNS requests to the main DNS server only for domain name.
“bogus-priv” avoids sending DNS requests to the main DNS server if it’s a local IP.
And finally, “expand-hosts” will be useful later to add a fake domain name to our local devices.
- Then add this line:
You can set anything you want
In my case, me.local will be my local domain name
If I have a host named “kodi”, I can now access it with “kodi.me.local”
We’ll see that later
- Save and exit (CTRL+O, CTRL+X)
- Restart DNSMasq to apply changes:
sudo service dnsmasq restart
Add a local host
To create a local host (as kodi.me.local), you need to add it in the hosts file
- Open the hosts file with nano
sudo nano /etc/hosts
- Add a line like this at the end
This line allows the Raspberry Pi to use “kodi” as a name to reach 192.168.1.17
After saving, you can ping kodi from the Raspberry Pi
- Save and exit (CTRL+O, CTRL+X)
The Raspberry Pi can now use kodi as a host name
And any computer using the Raspberry Pi as DNS server can use kodi.me.local
Before changing the computer configuration, we have to make sure the DNS server is now working correctly.
You can use nslookup to make DNS requests.
It’s a free tool available on any operating system.
- Start a terminal on your computer (command-line interface on Windows)
- Start nslookup
- By default, nslookup is using your current DNS server
You have to change it like this:
Replace A.B.C.D by the Raspberry Pi IP address
If you don’t know it you can read my post about how to get the Raspberry Pi IP address
- Then type any domain name to check that the Raspberry Pi is correctly resolving it
- It will show you an IP address corresponding to the domain name
Your DNS server is working
You can also try to resolve the local host (ex: kodi.local.me) to check that this is working too
The last step is to configure your computer to use the Raspberry Pi as a DNS server.
To do this, you have two options.
The first way is to configure the DNS server manually on your computer.
Depending on your operating system, you need to go in your network settings and set the main DNS server with the Raspberry Pi IP address.
On Windows, it’s in the Control Panel > Network and Internet > Network and Sharing Center > Change adapter settings.
Right-click on the network interface you are using and go into Properties.
Double-click on Internet Protocol Version 4 and the set the preferred DNS server with the Raspberry Pi IP address.
On Ubuntu/Debian you can change it directly in the /etc/resolv.conf file or in the network manager if you have a graphic desktop.
The other option is to change the DNS server in your DHCP server.
In the DHCP configuration, you can choose the IP range and the DNS server sent to clients.
If you have access to this, it’s probably the best option.
It’ll work directly with all your devices, including smartphones.
If you choose this option, don’t forget to set manually an external DNS server on your Raspberry Pi.
How to enable request caching on DNSMasq? DNSMasq use caching by default. If needed you can increase the cache-size value in the /etc/dnsmasq.conf file. For a small network, a value near 3000 should be fine.
How to measure the real Internet speed up with DNSMasq? The best option is to use the dig command from your computer. With a dig query (dig google.com) you get the corresponding IP, but also the query time. By using an Internet DNS server, query time will be at least 30ms each time. With a local server, the first one will be 30ms, and all the following under 5ms.
If you need a more step-by-step demonstration, I have recorded a video on the topic. You can watch it here if you want :
Subscribe to the RaspberryTips YouTube channel to receive new videos in your feed :
That’s it, you now know how to install a DNS server on Raspberry Pi, and how to configure it.
The goal of this tutorial was to show you the basics about DNS services
If you want to go further, I recommend you to read the official website for more options.
I didn’t write about the DHCP feature here as it was not the goal of this post, but you can use DNSMasq as a DHCP server too.
To use your Raspberry Pi as an all-in-one network server, you can also check my post on how to use it as Wireless Hotspot, router and firewall
The combination of the two tutorials should be perfect 🙂