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
  • 2019Blacklist Blog
    How does IP Address or Domain blacklist work? Network | Monitoring
  • RDP
    Fix Windows 11 Remote Desktop Connectivity Error code 0x204 Windows
  • image 9
    Fix Error 853: The remote access connection completed, but authentication failed because the certificate that authenticates the client to the server is not valid Network | Monitoring
  • screenshot 2020 04 18 at 00.01.07
    Different ways to check for Ansible syntax errors Configuration Management Tool
  • powershell commands lede 1024x276 1
    PowerShell Remoting: Guide to Windows Management Instrumentation Scripts
  • Perform slfservice rBitLocker recovery
    Resolve Invalid Key ID when requesting BitLocker Recovery Key Windows
  • 517443 637084112713220326 16x9 1
    How can I tell if a password is set for a user account on Linux Linux
  • article 1280x720.192a2586 1
    Windows 10 Always On VPN (AOVPN) Overview, features and Requirements Windows 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 Pocket (Opens in new window) Pocket
  • 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

  • Linux Shell Scripting 1
    Write a Shell Script that Count Lines and Words in a File Linux
  • selinux in production
    How to locate directory file context and restore it with SELinux Linux
  • linuxnethero
    Adding a subnetwork interface to an existing network interface Linux
  • redisf
    How to install Redis on Linux System Linux
  • FEATUREDC
    How to create Confidential VMs in Azure AWS/Azure/OpenShift
  • image 10
    Change Visual Studio Code UI language JIRA|Confluence|Apps

More Related Articles

Linux Shell Scripting 1 Write a Shell Script that Count Lines and Words in a File Linux
selinux in production How to locate directory file context and restore it with SELinux Linux
linuxnethero Adding a subnetwork interface to an existing network interface Linux
redisf How to install Redis on Linux System Linux
FEATUREDC How to create Confidential VMs in Azure AWS/Azure/OpenShift
image 10 Change Visual Studio Code UI language JIRA|Confluence|Apps

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

sysadmin top30a

  • 2019Blacklist Blog
    How does IP Address or Domain blacklist work? Network | Monitoring
  • RDP
    Fix Windows 11 Remote Desktop Connectivity Error code 0x204 Windows
  • image 9
    Fix Error 853: The remote access connection completed, but authentication failed because the certificate that authenticates the client to the server is not valid Network | Monitoring
  • screenshot 2020 04 18 at 00.01.07
    Different ways to check for Ansible syntax errors Configuration Management Tool
  • powershell commands lede 1024x276 1
    PowerShell Remoting: Guide to Windows Management Instrumentation Scripts
  • Perform slfservice rBitLocker recovery
    Resolve Invalid Key ID when requesting BitLocker Recovery Key Windows
  • 517443 637084112713220326 16x9 1
    How can I tell if a password is set for a user account on Linux Linux
  • article 1280x720.192a2586 1
    Windows 10 Always On VPN (AOVPN) Overview, features and Requirements Windows Server

Subscribe to Blog via Email

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

Join 1,836 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

AWS 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.