The sys admin's daily grind – Pdnsd
Short-Term Memory
Cache it, if you can! When the latencies of his Internet connection seem to take longer than Napoleon's reign, sys admin Charly comes up with a solution for name resolution.
It is always annoying when I need to use Internet via a satellite route. The latency is really bad. To counteract this, I use caching wherever I can. My choice of cache for DNS requests is Pdnsd [1]. More or less any fat distribution will have the lean and fast daemon in its collection. When launched, the daemon parses the content of /etc/hosts
and stores it in its cache. Any DNS requests that I make are added.
By default, the cache is 2MB. If you have built a very long /etc/hosts
throughout your IT landscape, you can modify the cache size in /etc/pdnsd.conf
. The matching option resides in the global
section. It goes by the name of perm_cache
and expects the size in bytes – I use 8192
. By the way, the option is named perm_cache
because the cache not only resides in RAM but also on the disk. In other words, Pdnsd does not need to build the cache from scratch after a reboot.
In the global
configuration section, you will find other central settings. One setting that is very important is:
server_ip = 127.0.0.1;
What this means is that Pdnsd only responds to DNS requests that come from localhost. If you want to allow other machines on the same network to submit IP requests to Pdnsd, you need to replace 127.0.0.1 with the interface that points to your internal network:
server_ip = eth1;
Options min_ttl
and max_ttl
let you define the minimum and maximum amounts of time the cache will keep an entry. The defaults – 15 minutes and one week – make a lot of sense in my opinion, and I tend to leave them that way. This is not true of the timeout
parameter, which is typically 10 seconds; this is not enough if you make generous use of a satellite route. I tend to double this value to timeout = 20s;
.
Say It!
After setting up a new Pdnsd, I like to make it more chatty by setting verbose = 3;
. (In difficult cases, I maximize the verbosity by setting debug = on
.) Once everything has reached a steady state, I comment out this option, and Pdnsd silently goes about its work.
Another option that I find useful is status_ctl = on
. It allows me to send commands to Pdnsd on the fly using the pdnsd-ctl
tool. Figure 1 shows the command
sudo pdnsd-ctl status
in action. Right at the top, you can see the cache utilization level, followed by an overview of the active threads and global configuration options. The sudo pdnsd-ctl empty-cache
command lets you empty the cache, which can be necessary after DNS changes if you do not want to wait until the TTL expires. You can type sudo pdnsd-ctl help
for an overview of the other commands.
Although Pdnsd is unable to cure latency in satellite connections, it can at least alleviate the pain – and that is a good thing.
Charly Kühnast
Charly Kühnast is a Unix operating system administrator at the Data Center in Moers, Germany. His tasks include firewall and DMZ security and availability. He divides his leisure time into hot, wet, and eastern sectors, where he enjoys cooking, freshwater aquariums, and learning Japanese, respectively.
Infos
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
![Learn More](https://www.linux-magazine.com/var/linux_magazin/storage/images/media/linux-magazine-eng-us/images/misc/learn-more/834592-1-eng-US/Learn-More_medium.png)
News
-
NVIDIA Released Driver for Upcoming NVIDIA 560 GPU for Linux
Not only has NVIDIA released the driver for its upcoming CPU series, it's the first release that defaults to using open-source GPU kernel modules.
-
OpenMandriva Lx 24.07 Released
If you’re into rolling release Linux distributions, OpenMandriva ROME has a new snapshot with a new kernel.
-
Kernel 6.10 Available for General Usage
Linus Torvalds has released the 6.10 kernel and it includes significant performance increases for Intel Core hybrid systems and more.
-
TUXEDO Computers Releases InfinityBook Pro 14 Gen9 Laptop
Sporting either AMD or Intel CPUs, the TUXEDO InfinityBook Pro 14 is an extremely compact, lightweight, sturdy powerhouse.
-
Google Extends Support for Linux Kernels Used for Android
Because the LTS Linux kernel releases are so important to Android, Google has decided to extend the support period beyond that offered by the kernel development team.
-
Linux Mint 22 Stable Delayed
If you're anxious about getting your hands on the stable release of Linux Mint 22, it looks as if you're going to have to wait a bit longer.
-
Nitrux 3.5.1 Available for Install
The latest version of the immutable, systemd-free distribution includes an updated kernel and NVIDIA driver.
-
Debian 12.6 Released with Plenty of Bug Fixes and Updates
The sixth update to Debian "Bookworm" is all about security mitigations and making adjustments for some "serious problems."
-
Canonical Offers 12-Year LTS for Open Source Docker Images
Canonical is expanding its LTS offering to reach beyond the DEB packages with a new distro-less Docker image.
-
Plasma Desktop 6.1 Released with Several Enhancements
If you're a fan of Plasma Desktop, you should be excited about this new point release.