Expert Network Time Protocol 260
Ben Rothke writes "If you review the thousands of Internet RFCs, you'd be hard pressed to find a protocol that lends itself to philosophical overtones, save for one -- the Network Time Protocol (NTP). The nature of time is abstract, difficult to measure and highly subjective. Yet time is a critical element in everyone's life, and in the effective operations of corporate networks." Read on for the rest of Rothke's review.
Expert Network Time Protocol: An Experience in Time with NTP | |
author | Peter Rybaczyk |
pages | 176 |
publisher | Apress |
rating | 9 |
reviewer | Ben Rothke |
ISBN | 1590594843 |
summary | Expert Network Time Protocol is a fascinating look into NTP, and the stories behind the science |
NTP is built on top of the TCP/IP protocol suite and is used to ensure accurate time-keeping with a trusted time reference. These references can be radio signals, GPS satellites, atomic clocks, Internet-based time servers and more. NTP is powerful enough to synchronize network clocks with millisecond accuracy.
In Expert Network Time Protocol: An Experience in Time with NTP, Peter Rybaczyk merges the philosophical aspects of time with the nuts of bolts of the NTP protocol. The book is composed of two parts, the first concerned with the meta-philosophy of time, and the second detailing the inner workings of NTP. The attempt in part one to merge technology and science with philosophy is a daunting task, and most often does not succeed. The notable exception to this is Douglas Hofstadter's Gödel, Escher, Bach: An Eternal Golden Braid.
Rybaczyk creates Sam, a fictional character who walks through the history of time. It is unclear who this Sam is -- whether he is supernatural being, or someone who got root on a time server. The author writes that the transcendental nature of time and the nuts and bolts of NTP are inseparable, but I personally found it difficult to determine what message part one was meant to convey. Fortunately, part one takes up but the first 34 pages.
Where the book shines, and where most readers will find value, is in part two, which details how to effectively design, configure, deploy and operate NTP. Where part one is conceptual, part two is extremely practical. Chapter 3 opens up with a comprehensive overview of the what, how and why effective time-keeping via NTP is needed.
The book details from a business perspective why synchronized and accurate time is a universal need. From transactional integrity, airline departures, sporting events, job shift changes, to FedEx pickups and more, nearly every activity requires time synchronization to work at peak levels. Effective network administration also requires time synchronization for network login procedures, directory synchronization, backups, and routing stability to work accurately.
From an information security perspective, password and digital ID synchronization, log file accuracy and auditing, and access control security are just a few of the areas where correct time can mean the difference between success and failure.
Where time synchronization is crucial, though, is in the realm of digital forensics. An otherwise painstaking digital forensic process might be worthless if time-related evidence from network devices is not correctly synchronized. If network devices are not correctly synchronized, you can basically forget about using them in any type of legal case.
Attorney Ronald Coleman, partner and computer law litigator at the New Jersey-based Coleman Law firm explains that in a computer law case involving serious discrepancies in network log times, the prosecution would conceivably drop the case. Similarly, a civil case to recover damages from an attacker is seriously undercut by these seemingly innocuous timing mistakes. "The network managers' lack of diligence at ensuring that the time was synchronized on their systems," explains Coleman, "opens them up to serious questions in front of a jury as to whether the logs and the system data are reliable at all -- especially with a gap of more than a couple of minutes, which might be explained away by which clocks were being relied on." In fact, an error of this magnitude would make the entire network administration suspect. That could be a disaster, Coleman says, where the network tracing record plus the human beings who sloppily set the automation in motion are going to be the chief sources of evidence against the alleged computer criminal. "A snafu such as seriously unsynchronized logs is just the sort of opening that could raise the level of doubt needed to undermine the other side's case."
Chapter 3 concludes with an interesting look at the cutting edge of time protocols, specifically the Interplanetary Internet. The Interplanetary Internet project is an attempt to synchronize computer time within the realm of deep space. NASA will in due time establish a deep space infrastructure whose purpose is to support the communication needs of multiple missions. Such an infrastructure would require time synchronization, but within a radically different framework from what exists today. The Interplanetary Internet and its underlying time synchronization are intended to solve that.
Chapter 4 brings the reader back to earth and provides vital information about how to design an effective NTP architecture. The key to designing the most appropriate NTP architecture for a given infrastructure is to first understand the different modes that NTP devices can operate in. The chapter details the five different NTP modes, the mode categories, and gives configuration information about each mode.
The chapter also provides information about NTP security. While NTP versions 3 and 4 provide added security (including symmetric private key cryptography and support of the Autokey protocol), it is ultimately up to the organization to determine what level of NTP security they need. Those organizations that don't require accurate time won't need much NTP security. But for those organizations who business requires synchronized and accurate time, such issues will drive the implementation of how they deploy NTP and its security functionality.
Chapter 5 details how organizational motivations (again, from a business perspective) will affect how you design your NTP architecture, and then describes several use scenarios. The book notes that designing an effective NTP deployment is a process that embodies four key steps: choosing a time source, deciding upon the NTP topology, determining the NTP features to configure, and then monitoring and managing the NTP operations. The chapter then goes on to describe various ways these steps can be carried out. The chapter provides a comprehensive overview on how to deploy NTP, be it on a dedicated time server, via already deployed products such as Cisco or Juniper routers, or on Unix/Linux/Windows file servers.
It is important to note that NTP is just the protocol. The actual implementation of NTP requires separate software client and server applications. The book focuses on the protocol and does not get into any specific vendors, other than a few screen shots from the configuration menu of a Symmetricom time server.
The author notes that on the surface, NTP is simple and almost inconspicuous, and overshadowed by better-known protocols such as HTTP, FTP and DNS. But once you start digging into NTP, you are dealing with one of the most pervasive elements of existence, namely time. Within NTP's scope, one could be dealing with atomic clocks, GPS satellites, clock selection, encryption algorithms and much more. So while at its heart, NTP may be a simple protocol, there is a complex infrastructure beneath it.
NTP is one of the most fundamental, yet overlooked services in the TCP/IP suite, and time synchronization is one of the most overlooked areas in networking. Hopefully, a book such as this can spark a renaissance. For far too long, time synchronization has not been afforded due diligence, and the effects have at times been disastrous. A view of the archives of the Risk Forum digest attests to this fact.
After a somewhat murky start in part one, Expert Network Time Protocol: An Experience in Time with NTP provides the reader with a superb synopsis of nearly everything he needs to know about NTP and effective time synchronization on his network, from an experienced implementer in the field. It is a fascinating look at one of the most humble, yet fundamental protocols on the Internet. For those who care about the correct time on their network, this book is required reading.
Ben Rothke, CISSP is a New-York based security consultant with ThruPoint, Inc. and the author of Computer Security: 20 Things Every Employee Should Know. He can be reached at ben@rothke.com You can purchase Expert Network Time Protocol: An Experience in Time with NTP from bn.com. Slashdot welcomes readers' book reviews -- to see your own review here, read the book review guidelines, then visit the submission page.
I thought I had time to read this (Score:4, Funny)
Re: (Score:2)
Can I get a cliff's notes version of the review... (Score:2, Funny)
Cliff sez... (Score:5, Insightful)
Really, all most of us need to know about NTP can be found on Ntp.org. [ntp.org]. Particularly useful is their NTP Pool project [ntp.org], which uses DNS aliasing to allow you to sync from random servers, and avoid placing a burden on any one server.
Re:Cliff sez... (Score:4, Insightful)
(Glances at shelf... sees "Longitude", Talbot's "The Holographic Universe", Glieck's "Chaos"... Ok, I never did read Longitude. That was for a Engineering Humanities course.)
Re:Cliff sez... (Score:4, Informative)
Re:Cliff sez... (Score:2)
Re:Cliff sez... (Score:2)
I read about the H&P of various obscure subjects myself. (And watch people's eyes glaze over when I talk about what I've read!) But I read about them in books that are about, not technical manuals that need filler. And yes, they're filler, because they'r
Re:Can I get a cliff's notes version of the review (Score:3, Informative)
Chapter 1: Sam sets up NTP on Linux
Section1: Sam meets the man in the Red Hat: In this chapter Sam types rpm -i ntp.rpm && ntpd
Section2: Sam meets Mandrake: In this chapter Sam types urpmi ntp && ntpd
Section3: Sam meets Gentoo: In this chapter Sam types emerge ntp && ntpd
Section 4: Sam meets Debian and battles the GNU: In this chapter Sam types apt-get install ntp && ntpd
Chapter 2: Sam set up NTP on other Unixes
Section 1: In this chapter Sam
Minor correction (Score:3, Informative)
Ummm, doesn't NTP run over UDP?
Re:Minor correction (Score:4, Informative)
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
No, there isn't. In common parlance, TCP/IP means all kinds of network protocols running on top of IP, such as TCP, UDP, ICMP, and others. If you specifically mean only TCP, then you just say TCP, not TCP/IP.
Re:Minor correction (Score:2)
Which I would assume would imply that they thought that the clumping together of TCP/IP was kind of misleading.
Re:No. TCP/IP refers to TCP and IP... (Score:2)
Actually, it says 'The generic term "TCP/IP" usually means anything and everything related to the specific protocols of TCP and IP. It can include other protocols, applications, and even the network medium. A sample of these protocols are: UDP, ARP, and ICMP. A sample of these applications are: TELNET, FTP, and rcp. A more accurate term is "internet technology". A network that uses internet technology is called an "internet".'
But I choose to rephrase that as "You're an idio
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
Re:Minor correction (Occam's Razor) (Score:2)
UDP and TCP are part of TCP/IP. (Just a question of whether we are working on level 3-4 or 4-5 on our OSI model.)
Ummm.... TCP/IP and OSI were designed to be completely separate networking protocol suites. Ultimately, TCP/IP does not mesh well with the OSI model.
After the failure of anyone to actually impliment OSI, it became a great tool to confuse wannabe network techs.
For the record, TCP/IP was designed around (and runs on) a 4-layer model. This mod
Re:Minor correction (Occam's Razor) (Score:2)
There are quite a few more than that [iana.org].
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
Re:Minor correction (Score:3, Informative)
> Ummm, doesn't NTP run over UDP?
The term "TCP/IP protocol suite" is somewhat of a misnomer. It is a network model that is comprised of:
* Application (OSI layers 5-7)
* Transport layer (OSI layer 4)
* Internetwork layer (OSI layer 3)
* Network Interface layer (OSI layers 1 & 2)
As such, UDP is a Transport layer protocol of the TCP/IP network model. Fun, ain't it?
Re:Minor correction (Score:5, Funny)
But this is all academic. Let's talk about boobies, err, I mean NTP.
Re:Minor correction (Score:2)
Yeah, that's a pet peeve. TCP/IP has nothing to do with OSI, but Cisco and other stupid certification mills would have you believe otherwise. There are many similarities, but there are just enough differences to cause serious confusion over the technical details.
Re:Minor correction (Score:2)
That's good news. When I studied for the CCNA, I had to study the Cisco interpretation of OSI and how Cisco wanted me to answer the questions.
The annoying part will be the legacy of this bizzare model... things like "Layer 4 switching" devices which aren't compatible with any OSI protocol.
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
No that means they are talking about TCP on top of IP. IP being the protocol to get from IP-address A to IP-address B. TCP being the stateful protocol that ensures data's arrival/correctness on a particular port.
Re:Minor correction (Score:2)
Re:Minor correction (Score:2)
meh (Score:4, Insightful)
All the computers in the network are within a second of eachother - and thats good nuff for me.
Re:meh (Score:5, Informative)
Yes, if you're into the meta-philosophy of timekeeping. If not, then the first part of this book obviously isn't for you.
All I know is that I have the two Domain Controllers sync to 6 outside machines (reliable servers)
Do you know enough about NTP to be able to evaluate whether those are good sources? If not, then the second part of this book may be useful.
All the computers in the network are within a second of eachother - and thats good nuff for me.
...you hope. As the reviewer said, precise synchronization is absolutely critical for forensic purposes. Can you conclusively demonstrate that Event A on machine Foo occurred before Event B on machine Bar? Would you be willing to testify to that fact if a conviction or monetary judgment were on the line?
Even if you don't think you need it, it's so trivially easy to get millisecond accuracy on all but the most unstable tickers that I never have understood why people don't sync their computers. If nothing else, it's nice to be able to set your watch to a known-accurate time source, then use that to set the rest of the clocks in your house. Am I the only one that hates seeing different times on the combination oven and microwave that has two separate displays within two feet?
Re:meh (Score:2)
If you think your machines are synced closer than that... your probably lieing. Remember that the internal clocks run at slightly different rates between hardware vendors. While two nearly identicle machines will slow down at the same rate (which is fine), two machines from different companies will speed up/slow down
Re:meh (Score:2)
Actually there is... a properly set up NTP infrastructure. The NTP server on each host not only periodically resynchronizes to known good time sources, but uses the results of those synchronizations to track the drift of it's own internal clock, which then allows it to compensate (generally quit
Re:meh (Score:2)
That's why we have a drift file [apac.edu.au]. As more and more NTP synchs happen the drift file becomes more and more precise. Maybe a couple days or so depending on update frequency (I usually update at 1024 seconds) the clock will eventually converge with the authoritative time server.
I once had two machines that were only sync'd about once a day.
You may want to increase that, if you are concerned about accuracy. IIRC
Re:meh (Score:2)
The review mentions forensics, but I would extend it to any time when you need to check log files with time stamps on two seperate machines. Having accurate clocks saves a lot of hassle.
Re:meh (Score:2)
I don't understand. My clocks always show the same number. On the other hand, I get really annoyed by the flashing being out of sync between all the kitchen applicances...
Re:meh (Score:2)
Well, since different observers have different simultaneity space-times, in general two observers cannot be assumed to agree on whether event A preceded or followed event B. (if it event B does not reside
Re:meh (Score:2)
Re:meh (Score:2)
Its called a cell phone.
Good for you. I prefer a nicely analog Swiss model, myself. My timepiece of choice isn't very external-clock compatible.
Re:meh (Score:4, Insightful)
1) It's important
2) You want to sync at least 2 internal machines to more than one outside system
3) You want to have internal machines sync against your two internal machines from (2)
The philosophy of time doesn't need to be in a book about NTP. Waste of paper, waste of print, waste of
Re:meh (Score:2)
Maybe... but when you really care about millisecond or sub-millisecond timing, you wind up digging pretty deep. And you have to understand that two clocks will differ from each other; you can't have two separate clocks in exact lock-step. At some resolution of measure, they _are_ going to differ over time.
To complicate matters: Oscillators speed up and slow down. Network traffic varies over time. Network delays are asymmetric. Server response del
Not for Windows users, or BSD users (Score:2)
It works fine in BSD, but you dont need a whole book, just tick the NTP box during the install process. (Linux is probably the same).
Re:Not for Windows users, or BSD users (Score:5, Funny)
Re:Not for Windows users, or BSD users (Score:2)
All I ever found was SNTP and other names for "regularly poll some real server and smack the result into the clock".
No PLL, no filtering, no multiple sources, no local clock support, nothing.
Or do you mean an xntpd port to Windows?
Re:Not for Windows users, or BSD users (Score:2)
Re:Not for Windows users, or BSD users (Score:2)
Just checking today, this source [meinberg.de] seems more up to date.
Re:Not for Windows users, or BSD users (Score:2)
Re:Not for Windows users, or BSD users (Score:2)
I wondered if Windows really had a builtin NTP client, not the simple NTP (SNTP) that I know about. But I think it hasn't.
Re:Not for Windows users, or BSD users (Score:2)
I run ntpd on a Linux system to keep accurate time, and let the Windows sytems get their time from it over the LAN. SNTP is usable for that (not for syncing over a WAN link that is also used for other purposes). For that, a Windows version of ntpd is a much better choice.
Re:Not for Windows users, or BSD users (Score:2)
SNTP usually means "send a query, receive a response, put that time into the computer clock, wait some fixed amout of time, repeat".
This is not good on a WAN link because each query may be delayed a different amount of time (mainly depending on queue length on a maxed-out local connection) and thus the actual time set into the clock may vary so much that the clock sometimes steps backward.
A complete NTP implementation avoids this by using filtering and by steering
Re:Not for Windows users, or BSD users (Score:2)
Subjective? (Score:5, Funny)
A good description of NTP... (Score:4, Informative)
- shadowmatter
If you enjoyed this book... (Score:5, Funny)
Ping, For Dummies!
Gopher: The Next Generation
All you ever wanted to know about the "yes" command
Re:If you enjoyed this book... (Score:5, Funny)
Check out the first review for The Story About Ping. [amazon.com]
I prefer clockspeed's taiclock (Score:4, Interesting)
http://cr.yp.to/clockspeed.html [cr.yp.to]
Includes an SNTP client, TAI client, TAI server, and clock correction program. It's very simple and it keeps my entire cluster to within a very small amount of drift of the atomic clock, with the sync interval doubling at every sync.
I use SNTP to get Stratum-1 time from NIST, then TAI to serve Stratum-2 time to my cluster.
Re:I prefer clockspeed's taiclock (Score:5, Insightful)
Don't be so needlessly antisocial. Pick a nice public stratum-2 server [isc.org] and leave the big guys alone. It reduces load (thus latency, thus inaccuracy) at the top and probably gives you better accuracy, assuming you're not in the same building as tycho.
I'd much rather sync against my ISP's GPS-based NTP server than a better source far away. It's better in every way, and it won't make the stratum-1 guys want to punch you.
By the way, clockspeed hasn't been updated since October 1998. OpenNTPD [openntpd.org] is a light, modern client that you might wish to consider.
Re:I prefer clockspeed's taiclock (Score:2)
I usually use good ol' ISC ntpd, but I've been looking at OpenNTPD for leaf nodes. Do you have any links to criticisms handy? I remember one that included things like "it's mainly developed on OpenBSD" that seemed to be pretty well debunked.
Re:I prefer clockspeed's taiclock (Score:2)
ISC ntpd does the same thing (see "FREQUENCY DISCIPLINE" in ntpd(1) on a Unix machine near you). OpenNTPD depends on the kernel to Do The Right Thing, which the BSDs, at least, seem to do. It has the additional advantage of not being under Dan's Crackpot License so people who actually want to develop it have the legal right to do so, which makes it a much more attractive target for people who want to add features,
Re:I prefer clockspeed's taiclock (Score:2)
This means that if you have the SpeedStep technology in your computer, then RDTSC is not a reliable time source.
This should be noted as a particular caveat on anything relying on RDTSC as a reliable timer.
Re:I prefer clockspeed's taiclock (Score:2)
Also, his ego may be huge, but it's not entirely unwarranted. The man wrote qmail.
As a recovering hater (Score:2, Funny)
Time, is an illusion. (Score:2, Funny)
Re:Time is an illusion. (Score:2, Insightful)
Damn! (Score:5, Funny)
I tried to explain this to my boss when I showed up for work at 10:30 today. But he's such a moron, he didn't understand it. Instead of being impressed by my knowledge and intelligence, he fired me. Dammit!
Biggest complaint (Score:3, Funny)
Re:Biggest complaint (Score:2)
Re:Biggest complaint (Score:3, Insightful)
Now don't tell me you couldn't have found that using a 2-second google search...
You need a book for this? (Score:2)
C:\>net time
C:\>w32tm
C:\>w32tm -once (win 2k)
Re:You need a book for this? (Score:2)
Only if you want to understand what it's actually doing and intelligently discuss it. Otherwise, nope.
Re:You need a book for this? (Score:2)
He didn't create him (Score:3, Funny)
We do know, however, that he has a holographic partner named Al who talks to a computer named Ziggy a lot, and that he hopes that his next leap will be the leap home.
calendar puzzle (Score:5, Interesting)
explain.
Re:calendar puzzle (Score:4, Funny)
Re:calendar puzzle (Score:3, Informative)
Re:calendar puzzle (Score:2)
Re:calendar puzzle (Score:2)
They were still being changed "a month's rent."
Re:calendar puzzle (Score:2)
They were being cheated: they were being paid for the days they worked but charged for the month they rented, so they were screwed that month.
TWW
Nasty Microsoft Outlook Bug! (Score:3, Funny)
Re:calendar puzzle (Score:5, Informative)
I'd bet on the second explanation... see below excerpt:
In September 1752 the Julian calendar was replaced with the Gregorian calendar in Great Britain and its American colonies. The Julian calendar was 11 days behind the Gregorian calendar, so 14 September got to follow 2 September on the day of the change. The result was that between 3 and 13 September, absolutely nothing happened!
Re:calendar puzzle (Score:2)
cygwin settles the debate (Score:2, Informative)
Re:calendar puzzle (Score:2)
I'm not a time expert, but this, I believe, was related to the transition from Julian to Gregorian time or some other form of seasonal adjustment. Prior to 1752, the solistices and equinoxes were over a week off from their historically recorded "official" dates on the Western calendar. I'm sure some other /.'er will provide a Wikipedia link to the exact explaination...
Simultaneity (Score:3, Insightful)
In a relativistic universe, the concept of absolute simultaneity is gone. Given two events separated in space (like two nearby supernovae, or two alarm clocks going off), depending on their speeds and distances, two observers may disagree on which one occurred first, even after they make various relativistic corrections for their own speed.
If two observers can't agree on simultaneity of two events, they will not be able to agree on the correct time.
Of course, this won't matter practically within the solar system, but between solar systems, it could start to make a difference.
Re:Simultaneity (Score:2)
Re:Simultaneity (Score:2)
"Becoming"? Where have you been? The Cray-2, vintage 1985, was a big circular computer because that minimized the lengths of the wiring for exactly that reason.
Re:Simultaneity (Score:2)
The question I want answered is. (Score:4, Funny)
With apologies to Peter Lorre (Score:5, Interesting)
I think time is a crook".
From "Beat The Devil", 1953:
http://www.imdb.com/title/tt0046414/ [imdb.com]
The great thing about humans is that... (Score:2)
Is it really that complicated? (Score:2)
Maybe this is why I'm not a protocol engineer.
Re:Is it really that complicated? (Score:2)
Re:Is it really that complicated? (Score:3, Informative)
Of course, the interesting part is that packets don't travel instantaneously. It's not enough to ask what the time is - you also need to know how long it takes the responder to answer. Furthermore, travel times aren't symmetric and you have to estimate how much of the total elapsed time between sending the request and receiving the answer occurs during each leg of the trip. Remember, the other guy faces the same constraints that you do - you can't just ask him for the an
Re:Is it really that complicated? (Score:3, Interesting)
I used to be. And I knew Dave Mills, who designed NTP.
There are quite a number of problems in time synchronization. Here are a few of them.
SNTP (Score:2)
Re:SNTP (Score:2)
That is not a good thing.
Set your time wrong, lose your case? (Score:2, Interesting)
I don't need no stinking time server! (Score:3, Funny)
Re:There is no such thing as time... (Score:2)
According to your argument, distance also doesn't exist. In fact I bet you could use your argument to prove that nothing really exists.
p.s. that means your argument is crap.