Network Time Protocol
The Network Time Protocol (NTP) is a program for synchronising the clocks of computer systems over packet-switched, variable-latency data networks. Although NTP is most commonly used in conjunction with UDP/IP protocol, it can also be transported over other network protocols such as TCP/IP. It is designed particularly to resist the effects of variable latency.
Internet protocol suite Application layer FTP SMTP HTTP IRC ... Transport layer TCP UDP SCTP ICMP ... Network layer IP IPv6 ARP DHCP ... Data link layer Ethernet Token ring FDDI 802.11 WiFi ...
NTP uses Marzullo's algorithm (invented by Keith Marzullo of University of California, San Diego in his dissertation) with the UTC time scale, including support for features such as leap seconds. NTPv4 can usually maintain time to within 10 milliseconds (1/100 s) over the public Internet, and can achieve accuracies of 200 microseconds (1/5000 s) or better in local area networks under ideal conditions.
It makes use of variations in latency in transmitting data packets across a network to synchronize computer clocks.
NTP is one of the oldest TCP/IP protocols still in use. NTP was originally designed by Dave Mills of the University of Delaware, who still maintains it. The current version is NTP version 4.
The NTP daemon is a user-level process that runs continuously on a machine that supports NTP, and most of the protocol is implemented in this user process. To get the best performance from NTP, it is important to have the standard NTP clock phase-locked loop implemented in the operating system kernel, rather than using only the intervention of the external NTP daemon: all recent versions of the Linux operating system have this support.
NTP uses a hierarchical system of "clock strata", where stratum 1 systems are synchronised to an accurate external clock such as a GPS clock or other radio clock. NTP stratum 2 systems derive their time from one or more stratum 1 systems, and so on. (Note that this is different from the notion of clock stratum used in telecommunications systems).
The 64-bit timestamps used by NTP consist of a 32-bit seconds part and a 32-bit fractional second part, giving NTP a time scale of 232 seconds, with a theoretical resolution of 2-32 seconds. Although the NTP timescale wraps round every 232 seconds, implementations should disambiguate NTP time using a knowledge of the approximate time from other sources. Since this only requires time accurate to a few decades, this is not a problem in general use.
A less complex form of NTP that does not require storing information about previous communications is known as the Simple Network Time Protocol or SNTP. It has gained a following in embedded devices and in applications where extremely high accuracy is not required.
The operational details of NTP are illustrated in RFCss 778, 891, 956, 958, 1305, and 2030. NTP should not be confused with the daytime (RFC 867) or time (RFC 868) protocols.
Besides the reference software implementation of NTP, which can be found on the NTP homepage and for which ports to the most popular operating systems exist, a number of manufacturers offer standalone timeserver appliances like Meinberg, FEI-Zyfer and others. These dedicated servers can provide accurate time to computer networks of any size.
See also
External links
General NTP links:
NTP-related software:
Manufacturers of NTP-based timeservers:
