Skip to content

TechDirectArchive

Hands-on IT, Cloud, Security & DevOps Insights

  • Home
  • About
  • Advertise With US
  • Reviews
  • Contact
  • Toggle search form
Home » Linux » How to setup a cache-only DNS server

How to setup a cache-only DNS server

Posted on 15/11/202010/09/2023 Christian By Christian No Comments on How to setup a cache-only DNS server
setup cache-only DNS server

A cache-only dns server (also known as a resolver) queries for information from other servers and stores the result of such queries in a memory cache for future use. This is a useful exercise in the event of repeating a request for a second time; a second (& similar) query will return a result in a shorter time when compared to the time the result was returned for the first query.

SETUP


1: Install the bind package

If it hasn’t been previously installed, use the following command to install the bind package:

yum install bind bind-utils -y

2. Edit the named.conf file


The configuration file is by default called named.conf and it is located in the etc directory. Open this file with a text editor and make the following changes;

listen-on port 53 {127.0.0.1; any;};
      allow-query {localhost; any;};
      allow-query-cache {localhost; any;};
      recursion yes; 

The next two images are the default configuration file and the edited configuration file. Make the necessary adjustment as indicated by the marked part of the images. Ensure you have the correct port number as this will be used in altering the firewall to allow traffic through.

configure cache-only DNS,
cache-only DNS setup

Save and quit the editor.

3. Confirm file ownership


Ensure that the file ownership for named.conf is still root:named. You can use the following command to view the ownership:

ls –lZ /etc/named.conf
DNS server configuration

If for whatever reason the ownership has changed, use the chown command to make the ownership root:named.

If the server is enabled by selinux, you will need to ensure you have the right selinux context. Just to be on the safe side, run the chcon command as ssen in the image below.

setup cache-only DNS server
  • 4. Test the configuration
    After making the above configurations, test the configuration to ensure you have the right settings. If the settings are right the checkconf command should retun no result. The checkconf command is; named-checkconf /etc/named.conf
configure cache-only DNS

5. Restart and enable
Restart the named service and it to ensure it is persistent across reboot. You can also check the status of the named service.

cache-only DNS setup

6. Edit the firewall configuration


Furthermore, Edit the firewall configuration to allow the stated port through the firewall. Then reload the firewall afterward

7. Test the setup
However, Use the dig command to test the setup. The dig command is used as follows;

   dig active-web-address

 The command to test my setup will look like; dig facebook.com

Moreover, The above image is the result of the first query. Note the query time; compare it with the query time for the second query, which is the image below.

SETTING UP A CLIENT SIDE
You can also latch on to the cache-only dns server from a client machine such that the client machine can also have a cache service when running queries.

Open up the ifcfg file on the client machine as follows;

vi /etc/sysconfig/network-scripts/ifcfg-ens33

The network interface I am using is ens33; remember to alter the command to accommodate the interface on your machine

Make the following changes to this file;

DNS1=ip-address-of-dns-server
IPPADDR=ip-address-of-client-machine
GATEWAY=network-gateway

Now restart the network service on the client machine and run the dig command on an active website. Then run the command again; note the query times for both command

I hope you found this blog post helpful. If you have any questions, please let me know in the comment session. I welcome you to follow me on Twitter and Facebook.

Rate this post

Thank you for reading this post. Kindly share it with others.

  • Share on X (Opens in new window) X
  • Share on Reddit (Opens in new window) Reddit
  • Share on LinkedIn (Opens in new window) LinkedIn
  • Share on Facebook (Opens in new window) Facebook
  • Share on Pinterest (Opens in new window) Pinterest
  • Share on Tumblr (Opens in new window) Tumblr
  • Share on Telegram (Opens in new window) Telegram
  • Share on WhatsApp (Opens in new window) WhatsApp
  • Share on Mastodon (Opens in new window) Mastodon
  • Share on Bluesky (Opens in new window) Bluesky
  • Share on Threads (Opens in new window) Threads
  • Share on Nextdoor (Opens in new window) Nextdoor
Linux Tags:DNS

Post navigation

Previous Post: How to enable or disable automatic software updates on Mac
Next Post: How to disable RC4 Cipher Algorithms support in SSH Server

Related Posts

  • Feature Image DNF vs APT
    What are the differences between dnf and apt package managers? Linux
  • whois4578uh
    How to get Domain information using WHOIS Command in Linux Linux
  • Install Packages to Amazon Virtual Machine Using Terraform
    How to Install Packages to Amazon VM using Terraform AWS/Azure/OpenShift
  • how to install software packages from source files
    How to install a software package from source file in Linux Linux
  • 517443 637286201540125528 16x9 1
    User account and process management in Linux Linux
  • 517443 637084112713220326 16x9 1
    How can I tell if a password is set for a user account on Linux Linux

More Related Articles

Feature Image DNF vs APT What are the differences between dnf and apt package managers? Linux
whois4578uh How to get Domain information using WHOIS Command in Linux Linux
Install Packages to Amazon Virtual Machine Using Terraform How to Install Packages to Amazon VM using Terraform AWS/Azure/OpenShift
how to install software packages from source files How to install a software package from source file in Linux Linux
517443 637286201540125528 16x9 1 User account and process management in Linux Linux
517443 637084112713220326 16x9 1 How can I tell if a password is set for a user account on Linux Linux

Leave a Reply Cancel reply

You must be logged in to post a comment.

Microsoft MVP

VEEAMLEGEND

vexpert-badge-stars-5

Virtual Background

GoogleNews

Categories

veeaam100

Veeam Vanguard

  • Microsoft LAPS
    Configure Windows LAPS Management with Microsoft Intune AWS/Azure/OpenShift
  • image 29
    How to force your website to redirect from HTTP to HTTPS using a web.config file Network | Monitoring
  • powerpoint 1280x720 1
    How to change the speller and proofing language in PowerPoint Microsoft Exchange/Office/365
  • ios microsoft remote desktop app
    Remote Desktop can not find the computer FQDN and this might mean that FQDN does not belong to the specified network Windows
  • Panic failed
    Panic: Failed to register the GitLab-runner, you may be having network issues Version Control System
  • systemd services
    How to use Systemd Timers on Linux Linux
  • dfefeq
    Error 740: Elevated permissions are required to run DISM Windows Server
  • RemoteDesktopLinceseServer
    Fix Remote session was disconnected because there are no Remote Desktop License Servers available to provide a license Network | Monitoring

Subscribe to Blog via Email

Enter your email address to subscribe to this blog and receive notifications of new posts by email.

Join 1,811 other subscribers
  • RSS - Posts
  • RSS - Comments
  • About
  • Authors
  • Write for us
  • Advertise with us
  • General Terms and Conditions
  • Privacy policy
  • Feedly
  • Telegram
  • Youtube
  • Facebook
  • Instagram
  • LinkedIn
  • Tumblr
  • Pinterest
  • Twitter
  • mastodon

Tags

Active Directory Azure Bitlocker Microsoft Windows PowerShell WDS Windows 10 Windows 11 Windows Deployment Services Windows Server 2016

Copyright © 2025 TechDirectArchive

 

Loading Comments...
 

You must be logged in to post a comment.