1@node ntpd Invocation 2@section Invoking ntpd 3@pindex ntpd 4@cindex NTP daemon program 5@ignore 6# 7# EDIT THIS FILE WITH CAUTION (invoke-ntpd.texi) 8# 9# It has been AutoGen-ed June 6, 2023 at 04:37:42 AM by AutoGen 5.18.16 10# From the definitions ntpd-opts.def 11# and the template file agtexi-cmd.tpl 12@end ignore 13 14 15 16The 17@code{ntpd} 18utility is an operating system daemon which sets 19and maintains the system time of day in synchronism with Internet 20standard time servers. 21It is a complete implementation of the 22Network Time Protocol (NTP) version 4, as defined by RFC-5905, 23but also retains compatibility with 24version 3, as defined by RFC-1305, and versions 1 25and 2, as defined by RFC-1059 and RFC-1119, respectively. 26 27The 28@code{ntpd} 29utility does most computations in 64-bit floating point 30arithmetic and does relatively clumsy 64-bit fixed point operations 31only when necessary to preserve the ultimate precision, about 232 32picoseconds. 33While the ultimate precision is not achievable with 34ordinary workstations and networks of today, it may be required 35with future gigahertz CPU clocks and gigabit LANs. 36 37Ordinarily, 38@code{ntpd} 39reads the 40@code{ntp.conf(5)} 41configuration file at startup time in order to determine the 42synchronization sources and operating modes. 43It is also possible to 44specify a working, although limited, configuration entirely on the 45command line, obviating the need for a configuration file. 46This may 47be particularly useful when the local host is to be configured as a 48broadcast/multicast client, with all peers being determined by 49listening to broadcasts at run time. 50 51If NetInfo support is built into 52@code{ntpd} 53then 54@code{ntpd} 55will attempt to read its configuration from the 56NetInfo if the default 57@code{ntp.conf(5)} 58file cannot be read and no file is 59specified by the 60@code{-c} 61option. 62 63Various internal 64@code{ntpd} 65variables can be displayed and 66configuration options altered while the 67@code{ntpd} 68is running 69using the 70@code{ntpq(1ntpqmdoc)} 71and 72@code{ntpdc(1ntpdcmdoc)} 73utility programs. 74 75When 76@code{ntpd} 77starts it looks at the value of 78@code{umask(2)}, 79and if zero 80@code{ntpd} 81will set the 82@code{umask(2)} 83to 022. 84 85This section was generated by @strong{AutoGen}, 86using the @code{agtexi-cmd} template and the option descriptions for the @code{ntpd} program. 87This software is released under the NTP license, <http://ntp.org/license>. 88 89@menu 90* ntpd usage:: ntpd help/usage (@option{--help}) 91* ntpd ipv4:: ipv4 option (-4) 92* ntpd ipv6:: ipv6 option (-6) 93* ntpd authreq:: authreq option (-a) 94* ntpd authnoreq:: authnoreq option (-A) 95* ntpd configfile:: configfile option (-c) 96* ntpd driftfile:: driftfile option (-f) 97* ntpd panicgate:: panicgate option (-g) 98* ntpd force-step-once:: force-step-once option (-G) 99* ntpd jaildir:: jaildir option (-i) 100* ntpd interface:: interface option (-I) 101* ntpd keyfile:: keyfile option (-k) 102* ntpd logfile:: logfile option (-l) 103* ntpd novirtualips:: novirtualips option (-L) 104* ntpd modifymmtimer:: modifymmtimer option (-M) 105* ntpd nice:: nice option (-N) 106* ntpd pidfile:: pidfile option (-p) 107* ntpd priority:: priority option (-P) 108* ntpd quit:: quit option (-q) 109* ntpd propagationdelay:: propagationdelay option (-r) 110* ntpd saveconfigquit:: saveconfigquit option 111* ntpd statsdir:: statsdir option (-s) 112* ntpd trustedkey:: trustedkey option (-t) 113* ntpd user:: user option (-u) 114* ntpd updateinterval:: updateinterval option (-U) 115* ntpd wait-sync:: wait-sync option (-w) 116* ntpd slew:: slew option (-x) 117* ntpd usepcc:: usepcc option 118* ntpd pccfreq:: pccfreq option 119* ntpd mdns:: mdns option (-m) 120* ntpd config:: presetting/configuring ntpd 121* ntpd exit status:: exit status 122* ntpd Usage:: Usage 123* ntpd Files:: Files 124* ntpd See Also:: See Also 125* ntpd Bugs:: Bugs 126* ntpd Notes:: Notes 127@end menu 128 129@node ntpd usage 130@subsection ntpd help/usage (@option{--help}) 131@cindex ntpd help 132 133This is the automatically generated usage text for ntpd. 134 135The text printed is the same whether selected with the @code{help} option 136(@option{--help}) or the @code{more-help} option (@option{--more-help}). @code{more-help} will print 137the usage text by passing it through a pager program. 138@code{more-help} is disabled on platforms without a working 139@code{fork(2)} function. The @code{PAGER} environment variable is 140used to select the program, defaulting to @file{more}. Both will exit 141with a status code of 0. 142 143@exampleindent 0 144@example 145ntpd - NTP daemon program - Ver. 4.2.8p17 146Usage: ntpd [ -<flag> [<val>] | --<name>[@{=| @}<val>] ]... \ 147 [ <server1> ... <serverN> ] 148 Flg Arg Option-Name Description 149 -4 no ipv4 Force IPv4 DNS name resolution 150 - prohibits the option 'ipv6' 151 -6 no ipv6 Force IPv6 DNS name resolution 152 - prohibits the option 'ipv4' 153 -a no authreq Require crypto authentication 154 - prohibits the option 'authnoreq' 155 -A no authnoreq Do not require crypto authentication 156 - prohibits the option 'authreq' 157 -b no bcastsync Allow us to sync to broadcast servers 158 -c Str configfile configuration file name 159 -d no debug-level Increase debug verbosity level 160 - may appear multiple times 161 -D Num set-debug-level Set the debug verbosity level 162 - may appear multiple times 163 -f Str driftfile frequency drift file name 164 -g no panicgate Allow the first adjustment to be Big 165 - may appear multiple times 166 -G no force-step-once Step any initial offset correction. 167 -i --- jaildir built without --enable-clockctl or --enable-linuxcaps or --enable-solarisprivs 168 -I Str interface Listen on an interface name or address 169 - may appear multiple times 170 -k Str keyfile path to symmetric keys 171 -l Str logfile path to the log file 172 -L no novirtualips Do not listen to virtual interfaces 173 -n no nofork Do not fork 174 - prohibits the option 'wait-sync' 175 -N no nice Run at high priority 176 -p Str pidfile path to the PID file 177 -P Num priority Process priority 178 -q no quit Set the time and quit 179 - prohibits these options: 180 saveconfigquit 181 wait-sync 182 -r Str propagationdelay Broadcast/propagation delay 183 Str saveconfigquit Save parsed configuration and quit 184 - prohibits these options: 185 quit 186 wait-sync 187 -s Str statsdir Statistics file location 188 -t Str trustedkey Trusted key number 189 - may appear multiple times 190 -u --- user built without --enable-clockctl or --enable-linuxcaps or --enable-solarisprivs 191 -U Num updateinterval interval in seconds between scans for new or dropped interfaces 192 Str var make ARG an ntp variable (RW) 193 - may appear multiple times 194 Str dvar make ARG an ntp variable (RW|DEF) 195 - may appear multiple times 196 -w Num wait-sync Seconds to wait for first clock sync 197 - prohibits these options: 198 nofork 199 quit 200 saveconfigquit 201 -x no slew Slew up to 600 seconds 202 opt version output version information and exit 203 -? no help display extended usage information and exit 204 -! no more-help extended usage information passed thru pager 205 206Options are specified by doubled hyphens and their name or by a single 207hyphen and the flag character. 208 209 210The following option preset mechanisms are supported: 211 - examining environment variables named NTPD_* 212 213Please send bug reports to: <https://bugs.ntp.org, bugs@@ntp.org> 214@end example 215@exampleindent 4 216 217@node ntpd ipv4 218@subsection ipv4 option (-4) 219@cindex ntpd-ipv4 220 221This is the ``force ipv4 dns name resolution'' option. 222 223@noindent 224This option has some usage constraints. It: 225@itemize @bullet 226@item 227must not appear in combination with any of the following options: 228ipv6. 229@end itemize 230 231Force DNS resolution of following host names on the command line 232to the IPv4 namespace. 233@node ntpd ipv6 234@subsection ipv6 option (-6) 235@cindex ntpd-ipv6 236 237This is the ``force ipv6 dns name resolution'' option. 238 239@noindent 240This option has some usage constraints. It: 241@itemize @bullet 242@item 243must not appear in combination with any of the following options: 244ipv4. 245@end itemize 246 247Force DNS resolution of following host names on the command line 248to the IPv6 namespace. 249@node ntpd authreq 250@subsection authreq option (-a) 251@cindex ntpd-authreq 252 253This is the ``require crypto authentication'' option. 254 255@noindent 256This option has some usage constraints. It: 257@itemize @bullet 258@item 259must not appear in combination with any of the following options: 260authnoreq. 261@end itemize 262 263Require cryptographic authentication for broadcast client, 264multicast client and symmetric passive associations. 265This is the default. 266@node ntpd authnoreq 267@subsection authnoreq option (-A) 268@cindex ntpd-authnoreq 269 270This is the ``do not require crypto authentication'' option. 271 272@noindent 273This option has some usage constraints. It: 274@itemize @bullet 275@item 276must not appear in combination with any of the following options: 277authreq. 278@end itemize 279 280Do not require cryptographic authentication for broadcast client, 281multicast client and symmetric passive associations. 282This is almost never a good idea. 283@node ntpd configfile 284@subsection configfile option (-c) 285@cindex ntpd-configfile 286 287This is the ``configuration file name'' option. 288This option takes a string argument. 289The name and path of the configuration file, 290@file{/etc/ntp.conf} 291by default. 292@node ntpd driftfile 293@subsection driftfile option (-f) 294@cindex ntpd-driftfile 295 296This is the ``frequency drift file name'' option. 297This option takes a string argument. 298The name and path of the frequency file, 299@file{/etc/ntp.drift} 300by default. 301This is the same operation as the 302@code{driftfile} @kbd{driftfile} 303configuration specification in the 304@file{/etc/ntp.conf} 305file. 306@node ntpd panicgate 307@subsection panicgate option (-g) 308@cindex ntpd-panicgate 309 310This is the ``allow the first adjustment to be big'' option. 311 312@noindent 313This option has some usage constraints. It: 314@itemize @bullet 315@item 316may appear an unlimited number of times. 317@end itemize 318 319Normally, 320@code{ntpd} 321exits with a message to the system log if the offset exceeds the panic threshold, which is 1000 s by default. This option allows the time to be set to any value without restriction; however, this can happen only once. If the threshold is exceeded after that, 322@code{ntpd} 323will exit with a message to the system log. This option can be used with the 324@code{-q} 325and 326@code{-x} 327options. 328See the 329@code{tinker} 330configuration file directive for other options. 331@node ntpd force-step-once 332@subsection force-step-once option (-G) 333@cindex ntpd-force-step-once 334 335This is the ``step any initial offset correction.'' option. 336Normally, 337@code{ntpd} 338steps the time if the time offset exceeds the step threshold, 339which is 128 ms by default, and otherwise slews the time. 340This option forces the initial offset correction to be stepped, 341so the highest time accuracy can be achieved quickly. 342However, this may also cause the time to be stepped back 343so this option must not be used if 344applications requiring monotonic time are running. 345See the @code{tinker} configuration file directive for other options. 346@node ntpd jaildir 347@subsection jaildir option (-i) 348@cindex ntpd-jaildir 349 350This is the ``jail directory'' option. 351This option takes a string argument. 352 353@noindent 354This option has some usage constraints. It: 355@itemize @bullet 356@item 357must be compiled in by defining @code{HAVE_DROPROOT} during the compilation. 358@end itemize 359 360Chroot the server to the directory 361@kbd{jaildir} 362. 363This option also implies that the server attempts to drop root privileges at startup. 364You may need to also specify a 365@code{-u} 366option. 367This option is only available if the OS supports adjusting the clock 368without full root privileges. 369This option is supported under NetBSD (configure with 370@code{--enable-clockctl}) or Linux (configure with 371@code{--enable-linuxcaps}) or Solaris (configure with @code{--enable-solarisprivs}). 372@node ntpd interface 373@subsection interface option (-I) 374@cindex ntpd-interface 375 376This is the ``listen on an interface name or address'' option. 377This option takes a string argument @file{iface}. 378 379@noindent 380This option has some usage constraints. It: 381@itemize @bullet 382@item 383may appear an unlimited number of times. 384@end itemize 385 386Open the network address given, or all the addresses associated with the 387given interface name. This option may appear multiple times. This option 388also implies not opening other addresses, except wildcard and localhost. 389This option is deprecated. Please consider using the configuration file 390@code{interface} command, which is more versatile. 391@node ntpd keyfile 392@subsection keyfile option (-k) 393@cindex ntpd-keyfile 394 395This is the ``path to symmetric keys'' option. 396This option takes a string argument. 397Specify the name and path of the symmetric key file. 398@file{/etc/ntp.keys} 399is the default. 400This is the same operation as the 401@code{keys} @kbd{keyfile} 402configuration file directive. 403@node ntpd logfile 404@subsection logfile option (-l) 405@cindex ntpd-logfile 406 407This is the ``path to the log file'' option. 408This option takes a string argument. 409Specify the name and path of the log file. 410The default is the system log file. 411This is the same operation as the 412@code{logfile} @kbd{logfile} 413configuration file directive. 414@node ntpd novirtualips 415@subsection novirtualips option (-L) 416@cindex ntpd-novirtualips 417 418This is the ``do not listen to virtual interfaces'' option. 419Do not listen to virtual interfaces, defined as those with 420names containing a colon. This option is deprecated. Please 421consider using the configuration file @code{interface} command, which 422is more versatile. 423@node ntpd modifymmtimer 424@subsection modifymmtimer option (-M) 425@cindex ntpd-modifymmtimer 426 427This is the ``modify multimedia timer (windows only)'' option. 428 429@noindent 430This option has some usage constraints. It: 431@itemize @bullet 432@item 433must be compiled in by defining @code{SYS_WINNT} during the compilation. 434@end itemize 435 436Set the Windows Multimedia Timer to highest resolution. This 437ensures the resolution does not change while ntpd is running, 438avoiding timekeeping glitches associated with changes. 439@node ntpd nice 440@subsection nice option (-N) 441@cindex ntpd-nice 442 443This is the ``run at high priority'' option. 444To the extent permitted by the operating system, run 445@code{ntpd} 446at the highest priority. 447@node ntpd pidfile 448@subsection pidfile option (-p) 449@cindex ntpd-pidfile 450 451This is the ``path to the pid file'' option. 452This option takes a string argument. 453Specify the name and path of the file used to record 454@code{ntpd}'s 455process ID. 456This is the same operation as the 457@code{pidfile} @kbd{pidfile} 458configuration file directive. 459@node ntpd priority 460@subsection priority option (-P) 461@cindex ntpd-priority 462 463This is the ``process priority'' option. 464This option takes a number argument. 465To the extent permitted by the operating system, run 466@code{ntpd} 467at the specified 468@code{sched_setscheduler(SCHED_FIFO)} 469priority. 470@node ntpd quit 471@subsection quit option (-q) 472@cindex ntpd-quit 473 474This is the ``set the time and quit'' option. 475 476@noindent 477This option has some usage constraints. It: 478@itemize @bullet 479@item 480must not appear in combination with any of the following options: 481saveconfigquit, wait-sync. 482@end itemize 483 484@code{ntpd} 485will not daemonize and will exit after the clock is first 486synchronized. This behavior mimics that of the 487@code{ntpdate} 488program, which will soon be replaced with a shell script. 489The 490@code{-g} 491and 492@code{-x} 493options can be used with this option. 494Note: The kernel time discipline is disabled with this option. 495@node ntpd propagationdelay 496@subsection propagationdelay option (-r) 497@cindex ntpd-propagationdelay 498 499This is the ``broadcast/propagation delay'' option. 500This option takes a string argument. 501Specify the default propagation delay from the broadcast/multicast server to this client. This is necessary only if the delay cannot be computed automatically by the protocol. 502@node ntpd saveconfigquit 503@subsection saveconfigquit option 504@cindex ntpd-saveconfigquit 505 506This is the ``save parsed configuration and quit'' option. 507This option takes a string argument. 508 509@noindent 510This option has some usage constraints. It: 511@itemize @bullet 512@item 513must be compiled in by defining @code{SAVECONFIG} during the compilation. 514@item 515must not appear in combination with any of the following options: 516quit, wait-sync. 517@end itemize 518 519Cause @code{ntpd} to parse its startup configuration file and save an 520equivalent to the given filename and exit. This option was 521designed for automated testing. 522@node ntpd statsdir 523@subsection statsdir option (-s) 524@cindex ntpd-statsdir 525 526This is the ``statistics file location'' option. 527This option takes a string argument. 528Specify the directory path for files created by the statistics facility. 529This is the same operation as the 530@code{statsdir} @kbd{statsdir} 531configuration file directive. 532@node ntpd trustedkey 533@subsection trustedkey option (-t) 534@cindex ntpd-trustedkey 535 536This is the ``trusted key number'' option. 537This option takes a string argument @file{tkey}. 538 539@noindent 540This option has some usage constraints. It: 541@itemize @bullet 542@item 543may appear an unlimited number of times. 544@end itemize 545 546Add the specified key number to the trusted key list. 547@node ntpd user 548@subsection user option (-u) 549@cindex ntpd-user 550 551This is the ``run as userid (or userid:groupid)'' option. 552This option takes a string argument. 553 554@noindent 555This option has some usage constraints. It: 556@itemize @bullet 557@item 558must be compiled in by defining @code{HAVE_DROPROOT} during the compilation. 559@end itemize 560 561Specify a user, and optionally a group, to switch to. 562This option is only available if the OS supports adjusting the clock 563without full root privileges. 564This option is supported under NetBSD (configure with 565@code{--enable-clockctl}) or Linux (configure with 566@code{--enable-linuxcaps}) or Solaris (configure with @code{--enable-solarisprivs}). 567@node ntpd updateinterval 568@subsection updateinterval option (-U) 569@cindex ntpd-updateinterval 570 571This is the ``interval in seconds between scans for new or dropped interfaces'' option. 572This option takes a number argument. 573Give the time in seconds between two scans for new or dropped interfaces. 574For systems with routing socket support the scans will be performed shortly after the interface change 575has been detected by the system. 576Use 0 to disable scanning. 60 seconds is the minimum time between scans. 577@node ntpd wait-sync 578@subsection wait-sync option (-w) 579@cindex ntpd-wait-sync 580 581This is the ``seconds to wait for first clock sync'' option. 582This option takes a number argument. 583 584@noindent 585This option has some usage constraints. It: 586@itemize @bullet 587@item 588must be compiled in by defining @code{HAVE_WORKING_FORK} during the compilation. 589@item 590must not appear in combination with any of the following options: 591nofork, quit, saveconfigquit. 592@end itemize 593 594If greater than zero, alters @code{ntpd}'s behavior when forking to 595daemonize. Instead of exiting with status 0 immediately after 596the fork, the parent waits up to the specified number of 597seconds for the child to first synchronize the clock. The exit 598status is zero (success) if the clock was synchronized, 599otherwise it is @code{ETIMEDOUT}. 600This provides the option for a script starting @code{ntpd} to easily 601wait for the first set of the clock before proceeding. 602@node ntpd slew 603@subsection slew option (-x) 604@cindex ntpd-slew 605 606This is the ``slew up to 600 seconds'' option. 607Normally, the time is slewed if the offset is less than the step threshold, which is 128 ms by default, and stepped if above the threshold. 608This option sets the threshold to 600 s, which is well within the accuracy window to set the clock manually. 609Note: Since the slew rate of typical Unix kernels is limited to 0.5 ms/s, each second of adjustment requires an amortization interval of 2000 s. 610Thus, an adjustment as much as 600 s will take almost 14 days to complete. 611This option can be used with the 612@code{-g} 613and 614@code{-q} 615options. 616See the 617@code{tinker} 618configuration file directive for other options. 619Note: The kernel time discipline is disabled with this option. 620@node ntpd usepcc 621@subsection usepcc option 622@cindex ntpd-usepcc 623 624This is the ``use cpu cycle counter (windows only)'' option. 625 626@noindent 627This option has some usage constraints. It: 628@itemize @bullet 629@item 630must be compiled in by defining @code{SYS_WINNT} during the compilation. 631@end itemize 632 633Attempt to substitute the CPU counter for @code{QueryPerformanceCounter}. 634The CPU counter and @code{QueryPerformanceCounter} are compared, and if 635they have the same frequency, the CPU counter (RDTSC on x86) is 636used directly, saving the overhead of a system call. 637@node ntpd pccfreq 638@subsection pccfreq option 639@cindex ntpd-pccfreq 640 641This is the ``force cpu cycle counter use (windows only)'' option. 642This option takes a string argument. 643 644@noindent 645This option has some usage constraints. It: 646@itemize @bullet 647@item 648must be compiled in by defining @code{SYS_WINNT} during the compilation. 649@end itemize 650 651Force substitution the CPU counter for @code{QueryPerformanceCounter}. 652The CPU counter (RDTSC on x86) is used unconditionally with the 653given frequency (in Hz). 654@node ntpd mdns 655@subsection mdns option (-m) 656@cindex ntpd-mdns 657 658This is the ``register with mdns as a ntp server'' option. 659 660@noindent 661This option has some usage constraints. It: 662@itemize @bullet 663@item 664must be compiled in by defining @code{HAVE_DNSREGISTRATION} during the compilation. 665@end itemize 666 667Registers as an NTP server with the local mDNS server which allows 668the server to be discovered via mDNS client lookup. 669 670 671@node ntpd config 672@subsection presetting/configuring ntpd 673 674Any option that is not marked as @i{not presettable} may be preset by 675loading values from environment variables named @code{NTPD} and @code{NTPD_<OPTION_NAME>}. @code{<OPTION_NAME>} must be one of 676the options listed above in upper case and segmented with underscores. 677The @code{NTPD} variable will be tokenized and parsed like 678the command line. The remaining variables are tested for existence and their 679values are treated like option arguments. 680 681 682The command line options relating to configuration and/or usage help are: 683 684@subsubheading version (-) 685 686Print the program version to standard out, optionally with licensing 687information, then exit 0. The optional argument specifies how much licensing 688detail to provide. The default is to print just the version. The licensing information may be selected with an option argument. 689Only the first letter of the argument is examined: 690 691@table @samp 692@item version 693Only print the version. This is the default. 694@item copyright 695Name the copyright usage licensing terms. 696@item verbose 697Print the full copyright usage licensing terms. 698@end table 699 700@node ntpd exit status 701@subsection ntpd exit status 702 703One of the following exit values will be returned: 704@table @samp 705@item 0 (EXIT_SUCCESS) 706Successful program execution. 707@item 1 (EXIT_FAILURE) 708The operation failed or the command syntax was not valid. 709@end table 710@node ntpd Usage 711@subsection ntpd Usage 712@node ntpd Files 713@subsection ntpd Files 714@node ntpd See Also 715@subsection ntpd See Also 716@node ntpd Bugs 717@subsection ntpd Bugs 718@node ntpd Notes 719@subsection ntpd Notes 720