Tuning ntpd
Charly's Column – ntpd
Charly Kühnast, sys admin columnist for 15 years, is searching for lost microseconds.
Time is the topic I'm focusing on right now. On the one hand, I am of course happy to be celebrating the 25th anniversary of Linux Magazine and the fact that I have been allowed to contribute this column for more than 15 years. On the other hand, I am currently working on configuring my time servers. In the last issue [1], I briefly touched on the topic when we looked at ntpviz
, the statistics visualization tool for the Network Time Protocol daemon (ntpd
).
How to tune the time server for maximum accuracy using quite simple means was the topic in the October 2017 issue [2]. (Is it really already two years ago? How time flies.) At the time, I picked up a high-precision pulse per second (PPS) signal from GPS satellites. This allowed me to line up ticks received locally or from remote time servers to achieve microsecond accuracy on my server. Apart from scientific applications, nobody really needs that, but it's cool, so it was done.
When I tackled this configuration back in 2017, it was still by a fairly circuitous route. Feeding the PPS signal to ntpd
required additional software, which I found on GitHub. It's easier today. The two daemons involved, gpsd
and ntpd
, work hand in hand on my Debian 10 – and without any extra software.
I only have to tell the GPS daemon in the /etc/default/gpsd
configuration file where to find the GPS hardware. In my case, it is connected to a USB port, so I need the following line:
DEVICES="/dev/ttyUSB0"
Also the ntpd
configuration file is quickly completed with Listing 1. Lines 1 to 4 probably already exist in the file. It is important that one of them ends with the prefer
keyword. Lines 6 and 7 include the GPS time signal, but only for statistics. The noselect
keyword prevents it from actually being included in the calculations, because it is not very accurate. Lines 9 to 11, on the other hand, provide accuracy and bridge the gap to the PPS signal, which announces the beginning of a new second with high precision.
Listing 1
/etc/ntp.conf
01 server 0.de.pool.ntp.org prefer 02 server 1.de.pool.ntp.org iburst 03 server 2.de.pool.ntp.org iburst 04 server 3.de.pool.ntp.org iburst 05 06 server 127.127.28.0 minpoll4 noselect 07 fudge 127.127.28.0 refid GPS 08 09 server 127.127.22.0 minpoll 4 maxpoll 4 10 fudge 127.127.22.0 flag3 1 refid PPS 11 tos mindist 0.2
A Little Crazy
This allows my time signal to fluctuate by only a few millionths of a second (Figure 1). By the way, the deflections in the right part of the graph were caused by me frivolously moving the GPS antenna on the window sill.
Of course, my experiments did not go as smoothly as the story thus far suggests. In the first attempt, my time signal was no more accurate than before, whatever I did. After tearing my hair out for a couple of hours, it turned out that you can buy some GPS hardware that simply ignores the PPS signal. This realization cost me half an afternoon – it seemed to drag on endlessly if you ask me. On the other hand, time flies – but not always, apparently.
Infos
- "Charly's Column – ntpviz" by Charly Kühnast, Linux Magazine, issue 228, November 2019, p. 26
- "Charly's Column – Precision Timekeeping" by Charly Kühnast, Linux Magazine, issue 203, October 2017, http://www.linux-magazine.com/Issues/2017/203/Charly-s-Column-Precise-Timekeeping/(language)/eng-US
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.
News
-
Endless OS 6 has Arrived
After more than a year since the last update, the latest release of Endless OS is now available for general usage.
-
Fedora Asahi 40 Remix Available for Macs with Apple Silicon
If you've been anticipating KDE's Plasma 6 for your Apple Silicon-powered Mac, then you're in luck.
-
Red Hat Adds New Deployment Option for Enterprise Linux Platforms
Red Hat has re-imagined enterprise Linux for an AI future with Image Mode.
-
OSJH and LPI Release 2024 Open Source Pros Job Survey Results
See what open source professionals look for in a new role.
-
Proton 9.0-1 Released to Improve Gaming with Steam
The latest release of Proton 9 adds several improvements and fixes an issue that has been problematic for Linux users.
-
So Long Neofetch and Thanks for the Info
Today is a day that every Linux user who enjoys bragging about their system(s) will mourn, as Neofetch has come to an end.
-
Ubuntu 24.04 Comes with a “Flaw"
If you're thinking you might want to upgrade from your current Ubuntu release to the latest, there's something you might want to consider before doing so.
-
Canonical Releases Ubuntu 24.04
After a brief pause because of the XZ vulnerability, Ubuntu 24.04 is now available for install.
-
Linux Servers Targeted by Akira Ransomware
A group of bad actors who have already extorted $42 million have their sights set on the Linux platform.
-
TUXEDO Computers Unveils Linux Laptop Featuring AMD Ryzen CPU
This latest release is the first laptop to include the new CPU from Ryzen and Linux preinstalled.