xref: /freebsd/contrib/ntp/ntpq/ntpq.html (revision e9b1dc32c9bd2ebae5f9e140bfa0e0321bc366b5)
1<html lang="en">
2<head>
3<title>ntpq: Network Time Protocol Query User's Manual</title>
4<meta http-equiv="Content-Type" content="text/html">
5<meta name="description" content="ntpq: Network Time Protocol Query User's Manual">
6<meta name="generator" content="makeinfo 4.7">
7<link title="Top" rel="top" href="#Top">
8<link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage">
9<meta http-equiv="Content-Style-Type" content="text/css">
10<style type="text/css"><!--
11  pre.display { font-family:inherit }
12  pre.format  { font-family:inherit }
13  pre.smalldisplay { font-family:inherit; font-size:smaller }
14  pre.smallformat  { font-family:inherit; font-size:smaller }
15  pre.smallexample { font-size:smaller }
16  pre.smalllisp    { font-size:smaller }
17  span.sc { font-variant:small-caps }
18  span.roman { font-family: serif; font-weight: normal; }
19--></style>
20</head>
21<body>
22<h1 class="settitle">ntpq: Network Time Protocol Query User's Manual</h1>
23  <div class="shortcontents">
24<h2>Short Contents</h2>
25<ul>
26<a href="#Top">ntpq: Network Time Protocol Query User Manual</a>
27</ul>
28</div>
29
30
31
32<div class="node">
33<p><hr>
34<a name="Top"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-Description">ntpq Description</a>,
35Previous:&nbsp;<a rel="previous" accesskey="p" href="#dir">(dir)</a>,
36Up:&nbsp;<a rel="up" accesskey="u" href="#dir">(dir)</a>
37<br>
38</div>
39
40<h2 class="unnumbered">ntpq: Network Time Protocol Query User Manual</h2>
41
42<p>The <code>ntpq</code> utility program is used to
43monitor the operational status
44and determine the performance of
45<code>ntpd</code>, the NTP daemon.
46
47  <p>This document applies to version 4.2.8p12 of <code>ntpq</code>.
48
49<ul class="menu">
50<li><a accesskey="1" href="#ntpq-Description">ntpq Description</a>
51<li><a accesskey="2" href="#ntpq-Invocation">ntpq Invocation</a>:              Invoking ntpq
52<li><a accesskey="3" href="#Usage">Usage</a>
53<li><a accesskey="4" href="#Internal-Commands">Internal Commands</a>
54<li><a accesskey="5" href="#Control-Message-Commands">Control Message Commands</a>
55<li><a accesskey="6" href="#Status-Words-and-Kiss-Codes">Status Words and Kiss Codes</a>
56<li><a accesskey="7" href="#System-Variables">System Variables</a>
57<li><a accesskey="8" href="#Peer-Variables">Peer Variables</a>
58<li><a accesskey="9" href="#Clock-Variables">Clock Variables</a>
59</ul>
60
61<div class="node">
62<p><hr>
63<a name="ntpq-Description"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Usage">Usage</a>,
64Previous:&nbsp;<a rel="previous" accesskey="p" href="#Top">Top</a>,
65Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
66<br>
67</div>
68
69<!-- node-name,  next,  previous,  up -->
70<h3 class="section">Description</h3>
71
72<p>The <code>ntpq</code> utility program is used to monitor NTP daemon <code>ntpd</code> operations and determine performance.
73It uses the standard NTP mode 6 control message formats defined in
74Appendix B of the NTPv3 specification RFC1305.
75The same formats are used in NTPv4, although some of the variable names have changed and new ones added.
76The description on this page is for the NTPv4 variables.
77
78  <p>The program can be run either in interactive mode or controlled using command line arguments.  Requests to read and write arbitrary variables can be assembled, with raw and pretty-printed output options being available.  The <code>ntpq</code> can also obtain and print a list of peers in a common format by sending multiple queries to the server.
79
80  <p>If one or more request options is included on the command line when <code>ntpq</code> is executed, each of the requests will be sent to the NTP servers running on each of the hosts given as command line arguments, or on localhost by default.  If no request options are given, <code>ntpq</code> will attempt to read commands from the standard input and execute these on the NTP server running on the first host given on the command line, again defaulting to localhost when no other host is specified.  <code>ntpq</code> will prompt for commands if the standard input is a terminal device.
81
82  <p><code>ntpq</code> uses NTP mode 6 packets to communicate with the NTP server, and hence can be used to query any compatible server on the network which permits it.  Note that since NTP is a UDP protocol this communication will be somewhat unreliable, especially over large distances in terms of network topology.  <code>ntpq</code> makes one attempt to retransmit requests, and will time requests out if the remote host is not heard from within a suitable timeout time.
83
84  <p>Note that in contexts where a host name is expected, a <code>-4</code> qualifier preceding the host name forces DNS resolution to the IPv4 namespace, while a <code>-6</code> qualifier forces DNS resolution to the IPv6 namespace.
85
86  <p>For examples and usage, see the <a href="debug.html">NTP Debugging Techniques</a> page.
87
88<div class="node">
89<p><hr>
90<a name="ntpq-Invocation"></a>
91<br>
92</div>
93
94<h3 class="section">Invoking ntpq</h3>
95
96<p><a name="index-ntpq-1"></a><a name="index-standard-NTP-query-program-2"></a>
97
98  <p>The
99<code>ntpq</code>
100utility program is used to query NTP servers to monitor NTP operations
101and performance, requesting
102information about current state and/or changes in that state.
103The program may be run either in interactive mode or controlled using
104command line arguments.
105Requests to read and write arbitrary
106variables can be assembled, with raw and pretty-printed output
107options being available.
108The
109<code>ntpq</code>
110utility can also obtain and print a
111list of peers in a common format by sending multiple queries to the
112server.
113
114  <p>If one or more request options is included on the command line
115when
116<code>ntpq</code>
117is executed, each of the requests will be sent
118to the NTP servers running on each of the hosts given as command
119line arguments, or on localhost by default.
120If no request options
121are given,
122<code>ntpq</code>
123will attempt to read commands from the
124standard input and execute these on the NTP server running on the
125first host given on the command line, again defaulting to localhost
126when no other host is specified.
127The
128<code>ntpq</code>
129utility will prompt for
130commands if the standard input is a terminal device.
131
132  <p><code>ntpq</code>
133uses NTP mode 6 packets to communicate with the
134NTP server, and hence can be used to query any compatible server on
135the network which permits it.
136Note that since NTP is a UDP protocol
137this communication will be somewhat unreliable, especially over
138large distances in terms of network topology.
139The
140<code>ntpq</code>
141utility makes
142one attempt to retransmit requests, and will time requests out if
143the remote host is not heard from within a suitable timeout
144time.
145
146  <p>Note that in contexts where a host name is expected, a
147<code>-4</code>
148qualifier preceding the host name forces resolution to the IPv4
149namespace, while a
150<code>-6</code>
151qualifier forces resolution to the IPv6 namespace.
152For examples and usage, see the
153NTP Debugging Techniques
154page.
155
156  <p>Specifying a
157command line option other than
158<code>-i</code>
159or
160<code>-n</code>
161will
162cause the specified query (queries) to be sent to the indicated
163host(s) immediately.
164Otherwise,
165<code>ntpq</code>
166will attempt to read
167interactive format commands from the standard input.
168
169<h5 class="subsubsection">Internal Commands</h5>
170
171<p>Interactive format commands consist of a keyword followed by zero
172to four arguments.
173Only enough characters of the full keyword to
174uniquely identify the command need be typed.
175
176  <p>A
177number of interactive format commands are executed entirely within
178the
179<code>ntpq</code>
180utility itself and do not result in NTP
181requests being sent to a server.
182These are described following.
183     <dl>
184<dt><code>?</code> <code>[</code><kbd>command</kbd><code>]</code><br><dt><code>help</code> <code>[</code><kbd>command</kbd><code>]</code><dd>A
185?
186by itself will print a list of all the commands
187known to
188<code>ntpq</code>
189A
190?
191followed by a command name will print function and usage
192information about the command.
193<br><dt><code>addvars</code> <kbd>name</kbd><code>[=</code><kbd>value</kbd><code>]</code><code>[,...]</code><br><dt><code>rmvars</code> <kbd>name</kbd><code>[,...]</code><br><dt><code>clearvars</code><br><dt><code>showvars</code><dd>The arguments to this command consist of a list of
194items of the form
195<kbd>name</kbd><code>[=</code><kbd>value</kbd><code>]</code>,
196where the
197.No = Ns Ar value
198is ignored, and can be omitted,
199in requests to the server to read variables.
200The
201<code>ntpq</code>
202utility maintains an internal list in which data to be included in
203messages can be assembled, and displayed or set using the
204<code>readlist</code>
205and
206<code>writelist</code>
207commands described below.
208The
209<code>addvars</code>
210command allows variables and their optional values to be added to
211the list.
212If more than one variable is to be added, the list should
213be comma-separated and not contain white space.
214The
215<code>rmvars</code>
216command can be used to remove individual variables from the list,
217while the
218<code>clearvars</code>
219command removes all variables from the
220list.
221The
222<code>showvars</code>
223command displays the current list of optional variables.
224<br><dt><code>authenticate</code> <code>[yes|no]</code><dd>Normally
225<code>ntpq</code>
226does not authenticate requests unless
227they are write requests.
228The command
229<code>authenticate</code> <code>yes</code>
230causes
231<code>ntpq</code>
232to send authentication with all requests it
233makes.
234Authenticated requests causes some servers to handle
235requests slightly differently.
236The command
237<code>authenticate</code>
238causes
239<code>ntpq</code>
240to display whether or not
241it is currently authenticating requests.
242<br><dt><code>cooked</code><dd>Causes output from query commands to be "cooked", so that
243variables which are recognized by
244<code>ntpq</code>
245will have their
246values reformatted for human consumption.
247Variables which
248<code>ntpq</code>
249could not decode completely are
250marked with a trailing
251?.
252<br><dt><code>debug</code> <code>[more|less|off]</code><dd>With no argument, displays the current debug level.
253Otherwise, the debugging level is changed as indicated.
254<br><dt><code>delay</code> <code>[</code><kbd>milliseconds</kbd><code>]</code><dd>Specify a time interval to be added to timestamps included in
255requests which require authentication.
256This is used to enable
257(unreliable) server reconfiguration over long delay network paths
258or between machines whose clocks are unsynchronized.
259Actually the
260server does not now require timestamps in authenticated requests,
261so this command may be obsolete.
262Without any arguments, displays the current delay.
263<br><dt><code>drefid</code> <code>[hash|ipv4]</code><dd>Display refids as IPv4 or hash.
264Without any arguments, displays whether refids are shown as IPv4
265addresses or hashes.
266<br><dt><code>exit</code><dd>Exit
267<code>ntpq</code>
268<br><dt><code>host</code> <code>[</code><kbd>name</kbd><code>]</code><dd>Set the host to which future queries will be sent.
269The
270<kbd>name</kbd>
271may be either a host name or a numeric address.
272Without any arguments, displays the current host.
273<br><dt><code>hostnames</code> <code>[yes|no]</code><dd>If
274<code>yes</code>
275is specified, host names are printed in
276information displays.
277If
278<code>no</code>
279is specified, numeric
280addresses are printed instead.
281The default is
282<code>yes</code>,
283unless
284modified using the command line
285<code>-n</code>
286switch.
287Without any arguments, displays whether host names or numeric addresses
288are shown.
289<br><dt><code>keyid</code> <code>[</code><kbd>keyid</kbd><code>]</code><dd>This command allows the specification of a key number to be
290used to authenticate configuration requests.
291This must correspond
292to the
293<code>controlkey</code>
294key number the server has been configured to use for this
295purpose.
296Without any arguments, displays the current
297<kbd>keyid</kbd>.
298<br><dt><code>keytype</code> <code>[</code><kbd>digest</kbd><code>]</code><dd>Specify the digest algorithm to use for authenticating requests, with default
299<code>MD5</code>.
300If
301<code>ntpq</code>
302was built with OpenSSL support, and OpenSSL is installed,
303<kbd>digest</kbd>
304can be any message digest algorithm supported by OpenSSL.
305If no argument is given, the current
306<code>keytype</code> <kbd>digest</kbd>
307algorithm used is displayed.
308<br><dt><code>ntpversion</code> <code>[1|2|3|4]</code><dd>Sets the NTP version number which
309<code>ntpq</code>
310claims in
311packets.
312Defaults to 3, and note that mode 6 control messages (and
313modes, for that matter) didn't exist in NTP version 1.
314There appear
315to be no servers left which demand version 1.
316With no argument, displays the current NTP version that will be used
317when communicating with servers.
318<br><dt><code>passwd</code><dd>This command prompts you to type in a password (which will not
319be echoed) which will be used to authenticate configuration
320requests.
321The password must correspond to the key configured for
322use by the NTP server for this purpose if such requests are to be
323successful.
324<br><dt><code>poll</code> <code>[</code><kbd>n</kbd><code>]</code> <code>[verbose]</code><dd>Poll an NTP server in client mode
325<kbd>n</kbd>
326times.
327Poll not implemented yet.
328<br><dt><code>quit</code><dd>Exit
329<code>ntpq</code>
330<br><dt><code>raw</code><dd>Causes all output from query commands is printed as received
331from the remote server.
332The only formating/interpretation done on
333the data is to transform nonascii data into a printable (but barely
334understandable) form.
335<br><dt><code>timeout</code> <code>[</code><kbd>milliseconds</kbd><code>]</code><dd>Specify a timeout period for responses to server queries.
336The
337default is about 5000 milliseconds.
338Without any arguments, displays the current timeout period.
339Note that since
340<code>ntpq</code>
341retries each query once after a timeout, the total waiting time for
342a timeout will be twice the timeout value set.
343<br><dt><code>version</code><dd>Display the version of the
344<code>ntpq</code>
345program.
346</dl>
347
348<h5 class="subsubsection">Control Message Commands</h5>
349
350<p>Association ids are used to identify system, peer and clock variables.
351System variables are assigned an association id of zero and system name
352space, while each association is assigned a nonzero association id and
353peer namespace.
354Most control commands send a single message to the server and expect a
355single response message.
356The exceptions are the
357<code>peers</code>
358command, which sends a series of messages,
359and the
360<code>mreadlist</code>
361and
362<code>mreadvar</code>
363commands, which iterate over a range of associations.
364     <dl>
365<dt><code>apeers</code><dd>Display a list of peers in the form:
366     <pre class="example">          [tally]remote refid assid st t when pool reach delay offset jitter
367     </pre>
368     <p>where the output is just like the
369<code>peers</code>
370command except that the
371<code>refid</code>
372is displayed in hex format and the association number is also displayed.
373<br><dt><code>associations</code><dd>Display a list of mobilized associations in the form:
374     <pre class="example">          ind assid status conf reach auth condition last_event cnt
375     </pre>
376          <dl>
377<dt>Sy Variable Ta Sy Description<br><dt><code>ind</code> <code>Ta</code> <code>index</code> <code>on</code> <code>this</code> <code>list</code><br><dt><code>assid</code> <code>Ta</code> <code>association</code> <code>id</code><br><dt><code>status</code> <code>Ta</code> <code>peer</code> <code>status</code> <code>word</code><br><dt><code>conf</code> <code>Ta</code> <code>yes</code>: <code>No</code> <code>persistent,</code> <code>no</code>: <code>No</code> <code>ephemeral</code><br><dt><code>reach</code> <code>Ta</code> <code>yes</code>: <code>No</code> <code>reachable,</code> <code>no</code>: <code>No</code> <code>unreachable</code><br><dt><code>auth</code> <code>Ta</code> <code>ok</code>, <code>yes</code>, <code>bad</code> <code>No</code> <code>and</code> <code>none</code><br><dt><code>condition</code> <code>Ta</code> <code>selection</code> <code>status</code> <code>(see</code> <code>the</code> <code>select</code> <code>No</code> <code>field</code> <code>of</code> <code>the</code> <code>peer</code> <code>status</code> <code>word)</code><br><dt><code>last_event</code> <code>Ta</code> <code>event</code> <code>report</code> <code>(see</code> <code>the</code> <code>event</code> <code>No</code> <code>field</code> <code>of</code> <code>the</code> <code>peer</code> <code>status</code> <code>word)</code><br><dt><code>cnt</code> <code>Ta</code> <code>event</code> <code>count</code> <code>(see</code> <code>the</code> <code>count</code> <code>No</code> <code>field</code> <code>of</code> <code>the</code> <code>peer</code> <code>status</code> <code>word)</code><dd></dl>
378     <br><dt><code>authinfo</code><dd>Display the authentication statistics counters:
379time since reset, stored keys, free keys, key lookups, keys not found,
380uncached keys, expired keys, encryptions, decryptions.
381<br><dt><code>clocklist</code> <code>[</code><kbd>associd</kbd><code>]</code><br><dt><code>cl</code> <code>[</code><kbd>associd</kbd><code>]</code><dd>Display all clock variables in the variable list for those associations
382supporting a reference clock.
383<br><dt><code>clockvar</code> <code>[</code><kbd>associd</kbd><code>]</code> <code>[</code><kbd>name</kbd><code>[=</code><kbd>value</kbd><code>]]</code><code>[,...]</code><br><dt><code>cv</code> <code>[</code><kbd>associd</kbd><code>]</code> <code>[</code><kbd>name</kbd><code>[=</code><kbd>value</kbd><code>]]</code><code>[,...]</code><dd>Display a list of clock variables for those associations supporting a
384reference clock.
385<br><dt><code>:config</code> <kbd>configuration command line</kbd><dd>Send the remainder of the command line, including whitespace, to the
386server as a run-time configuration command in the same format as a line
387in the configuration file.
388This command is experimental until further notice and clarification.
389Authentication is of course required.
390<br><dt><code>config-from-file</code> <kbd>filename</kbd><dd>Send each line of
391<kbd>filename</kbd>
392to the server as run-time configuration commands in the same format as
393lines in the configuration file.
394This command is experimental until further notice and clarification.
395Authentication is required.
396<br><dt><code>ifstats</code><dd>Display status and statistics counters for each local network interface address:
397interface number, interface name and address or broadcast, drop, flag,
398ttl, mc, received, sent, send failed, peers, uptime.
399Authentication is required.
400<br><dt><code>iostats</code><dd>Display network and reference clock I/O statistics:
401time since reset, receive buffers, free receive buffers, used receive buffers,
402low water refills, dropped packets, ignored packets, received packets,
403packets sent, packet send failures, input wakeups, useful input wakeups.
404<br><dt><code>kerninfo</code><dd>Display kernel loop and PPS statistics:
405associd, status, pll offset, pll frequency, maximum error,
406estimated error, kernel status, pll time constant, precision,
407frequency tolerance, pps frequency, pps stability, pps jitter,
408calibration interval, calibration cycles, jitter exceeded,
409stability exceeded, calibration errors.
410As with other ntpq output, times are in milliseconds; very small values
411may be shown as exponentials.
412The precision value displayed is in milliseconds as well, unlike the
413precision system variable.
414<br><dt><code>lassociations</code><dd>Perform the same function as the associations command, except display
415mobilized and unmobilized associations, including all clients.
416<br><dt><code>lopeers</code> <code>[-4|-6]</code><dd>Display a list of all peers and clients showing
417<code>dstadr</code>
418(associated with the given IP version).
419<br><dt><code>lpassociations</code><dd>Display the last obtained list of associations, including all clients.
420<br><dt><code>lpeers</code> <code>[-4|-6]</code><dd>Display a list of all peers and clients (associated with the given IP version).
421<br><dt><code>monstats</code><dd>Display monitor facility status, statistics, and limits:
422enabled, addresses, peak addresses, maximum addresses,
423reclaim above count, reclaim older than, kilobytes, maximum kilobytes.
424<br><dt><code>mreadlist</code> <kbd>associdlo</kbd> <kbd>associdhi</kbd><br><dt><code>mrl</code> <kbd>associdlo</kbd> <kbd>associdhi</kbd><dd>Perform the same function as the
425<code>readlist</code>
426command for a range of association ids.
427<br><dt><code>mreadvar</code> <kbd>associdlo</kbd> <kbd>associdhi</kbd> <code>[</code><kbd>name</kbd><code>]</code><code>[,...]</code><dd>This range may be determined from the list displayed by any
428command showing associations.
429<br><dt><code>mrv</code> <kbd>associdlo</kbd> <kbd>associdhi</kbd> <code>[</code><kbd>name</kbd><code>]</code><code>[,...]</code><dd>Perform the same function as the
430<code>readvar</code>
431command for a range of association ids.
432This range may be determined from the list displayed by any
433command showing associations.
434<br><dt><code>mrulist</code> <code>[limited | kod | mincount=</code><kbd>count</kbd><code> | laddr=</code><kbd>localaddr</kbd><code> | sort=[-]</code><kbd>sortorder</kbd><code> | resany=</code><kbd>hexmask</kbd><code> | resall=</code><kbd>hexmask</kbd><code>]</code><dd>Display traffic counts of the most recently seen source addresses
435collected and maintained by the monitor facility.
436With the exception of
437<code>sort</code>=<code>[-]</code><kbd>sortorder</kbd>,
438the options filter the list returned by
439<code>ntpd(8)</code>.
440The
441<code>limited</code>
442and
443<code>kod</code>
444options return only entries representing client addresses from which the
445last packet received triggered either discarding or a KoD response.
446The
447<code>mincount</code>=<kbd>count</kbd>
448option filters entries representing less than
449<kbd>count</kbd>
450packets.
451The
452<code>laddr</code>=<kbd>localaddr</kbd>
453option filters entries for packets received on any local address other than
454<kbd>localaddr</kbd>.
455<code>resany</code>=<kbd>hexmask</kbd>
456and
457<code>resall</code>=<kbd>hexmask</kbd>
458filter entries containing none or less than all, respectively, of the bits in
459<kbd>hexmask</kbd>,
460which must begin with
461<code>0x</code>.
462The
463<kbd>sortorder</kbd>
464defaults to
465<code>lstint</code>
466and may be
467<code>addr</code>,
468<code>avgint</code>,
469<code>count</code>,
470<code>lstint</code>,
471or any of those preceded by
472-
473to reverse the sort order.
474The output columns are:
475          <dl>
476<dt>Column<dd>Description
477<br><dt><code>lstint</code><dd>Interval in seconds between the receipt of the most recent packet from
478this address and the completion of the retrieval of the MRU list by
479<code>ntpq</code>
480<br><dt><code>avgint</code><dd>Average interval in s between packets from this address.
481<br><dt><code>rstr</code><dd>Restriction flags associated with this address.
482Most are copied unchanged from the matching
483<code>restrict</code>
484command, however 0x400 (kod) and 0x20 (limited) flags are cleared unless
485the last packet from this address triggered a rate control response.
486<br><dt><code>r</code><dd>Rate control indicator, either
487a period,
488<code>L</code>
489or
490<code>K</code>
491for no rate control response,
492rate limiting by discarding, or rate limiting with a KoD response, respectively.
493<br><dt><code>m</code><dd>Packet mode.
494<br><dt><code>v</code><dd>Packet version number.
495<br><dt><code>count</code><dd>Packets received from this address.
496<br><dt><code>rport</code><dd>Source port of last packet from this address.
497<br><dt><code>remote</code> <code>address</code><dd>host or DNS name, numeric address, or address followed by
498claimed DNS name which could not be verified in parentheses.
499</dl>
500     <br><dt><code>opeers</code> <code>[-4 | -6]</code><dd>Obtain and print the old-style list of all peers and clients showing
501<code>dstadr</code>
502(associated with the given IP version),
503rather than the
504<code>refid</code>.
505<br><dt><code>passociations</code><dd>Perform the same function as the
506<code>associations</code>
507command,
508except that it uses previously stored data rather than making a new query.
509<br><dt><code>peers</code><dd>Display a list of peers in the form:
510     <pre class="example">          [tally]remote refid st t when pool reach delay offset jitter
511     </pre>
512          <dl>
513<dt>Variable<dd>Description
514<br><dt><code>[tally]</code><dd>single-character code indicating current value of the
515<code>select</code>
516field of the
517.Lk decode.html#peer "peer status word"
518<br><dt><code>remote</code><dd>host name (or IP number) of peer.
519The value displayed will be truncated to 15 characters unless the
520<code>ntpq</code>
521<code>-w</code>
522option is given, in which case the full value will be displayed
523on the first line, and if too long,
524the remaining data will be displayed on the next line.
525<br><dt><code>refid</code><dd>source IP address or
526.Lk decode.html#kiss "'kiss code"
527<br><dt><code>st</code><dd>stratum: 0 for local reference clocks, 1 for servers with local
528reference clocks, ..., 16 for unsynchronized server clocks
529<br><dt><code>t</code><dd><code>u</code>:
530unicast or manycast client,
531<code>b</code>:
532broadcast or multicast client,
533<code>p</code>:
534pool source,
535<code>l</code>:
536local (reference clock),
537<code>s</code>:
538symmetric (peer),
539<code>A</code>:
540manycast server,
541<code>B</code>:
542broadcast server,
543<code>M</code>:
544multicast server
545<br><dt><code>when</code><dd>time in seconds, minutes, hours, or days since the last packet
546was received, or
547-
548if a packet has never been received
549<br><dt><code>poll</code><dd>poll interval (s)
550<br><dt><code>reach</code><dd>reach shift register (octal)
551<br><dt><code>delay</code><dd>roundtrip delay
552<br><dt><code>offset</code><dd>offset of server relative to this host
553<br><dt><code>jitter</code><dd>offset RMS error estimate.
554</dl>
555     <br><dt><code>pstats</code> <kbd>associd</kbd><dd>Display the statistics for the peer with the given
556<kbd>associd</kbd>:
557associd, status, remote host, local address, time last received,
558time until next send, reachability change, packets sent,
559packets received, bad authentication, bogus origin, duplicate,
560bad dispersion, bad reference time, candidate order.
561<br><dt><code>readlist</code> <code>[</code><kbd>associd</kbd><code>]</code><br><dt><code>rl</code> <code>[</code><kbd>associd</kbd><code>]</code><dd>Display all system or peer variables.
562If the
563<kbd>associd</kbd>
564is omitted, it is assumed to be zero.
565<br><dt><code>readvar</code> <code>[</code><kbd>associd</kbd> <kbd>name</kbd><code>[=</code><kbd>value</kbd><code>] [, ...]]</code><br><dt><code>rv</code> <code>[</code><kbd>associd</kbd> <kbd>name</kbd><code>[=</code><kbd>value</kbd><code>] [, ...]]</code><dd>Display the specified system or peer variables.
566If
567<kbd>associd</kbd>
568is zero, the variables are from the
569<a href="#System-Variables">System Variables</a>
570name space, otherwise they are from the
571<a href="#Peer-Variables">Peer Variables</a>
572name space.
573The
574<kbd>associd</kbd>
575is required, as the same name can occur in both spaces.
576If no
577<kbd>name</kbd>
578is included, all operative variables in the name space are displayed.
579In this case only, if the
580<kbd>associd</kbd>
581is omitted, it is assumed to be zero.
582Multiple names are specified with comma separators and without whitespace.
583Note that time values are represented in milliseconds
584and frequency values in parts-per-million (PPM).
585Some NTP timestamps are represented in the format
586<kbd>YYYY</kbd><kbd>MM</kbd> <kbd>DD</kbd> <kbd>TTTT</kbd>,
587where
588<kbd>YYYY</kbd>
589is the year,
590<kbd>MM</kbd>
591the month of year,
592<kbd>DD</kbd>
593the day of month and
594<kbd>TTTT</kbd>
595the time of day.
596<br><dt><code>reslist</code><dd>Display the access control (restrict) list for
597<code>ntpq</code>
598Authentication is required.
599<br><dt><code>saveconfig</code> <kbd>filename</kbd><dd>Save the current configuration,
600including any runtime modifications made by
601<code>:config</code>
602or
603<code>config-from-file</code>,
604to the NTP server host file
605<kbd>filename</kbd>.
606This command will be rejected by the server unless
607.Lk miscopt.html#saveconfigdir "saveconfigdir"
608appears in the
609<code>ntpd(8)</code>
610configuration file.
611<kbd>filename</kbd>
612can use
613<code>date(1)</code>
614format specifiers to substitute the current date and time, for
615example,
616     <pre class="example">          <code>saveconfig</code> <span class="file">ntp-%Y%m%d-%H%M%S.conf</span>.
617     </pre>
618     <p>The filename used is stored in system variable
619<code>savedconfig</code>.
620Authentication is required.
621<br><dt><code>sysinfo</code><dd>Display system operational summary:
622associd, status, system peer, system peer mode, leap indicator,
623stratum, log2 precision, root delay, root dispersion,
624reference id, reference time, system jitter, clock jitter,
625clock wander, broadcast delay, symm. auth. delay.
626<br><dt><code>sysstats</code><dd>Display system uptime and packet counts maintained in the
627protocol module:
628uptime, sysstats reset, packets received, current version,
629older version, bad length or format, authentication failed,
630declined, restricted, rate limited, KoD responses,
631processed for time.
632<br><dt><code>timerstats</code><dd>Display interval timer counters:
633time since reset, timer overruns, calls to transmit.
634<br><dt><code>writelist</code> <kbd>associd</kbd><dd>Set all system or peer variables included in the variable list.
635<br><dt><code>writevar</code> <kbd>associd</kbd> <kbd>name</kbd>=<kbd>value</kbd> <code>[, ...]</code><dd>Set the specified variables in the variable list.
636If the
637<kbd>associd</kbd>
638is zero, the variables are from the
639<a href="#System-Variables">System Variables</a>
640name space, otherwise they are from the
641<a href="#Peer-Variables">Peer Variables</a>
642name space.
643The
644<kbd>associd</kbd>
645is required, as the same name can occur in both spaces.
646Authentication is required.
647</dl>
648
649<h5 class="subsubsection">Status Words and Kiss Codes</h5>
650
651<p>The current state of the operating program is shown
652in a set of status words
653maintained by the system.
654Status information is also available on a per-association basis.
655These words are displayed by the
656<code>readlist</code>
657and
658<code>associations</code>
659commands both in hexadecimal and in decoded short tip strings.
660The codes, tips and short explanations are documented on the
661.Lk decode.html "Event Messages and Status Words"
662page.
663The page also includes a list of system and peer messages,
664the code for the latest of which is included in the status word.
665
666  <p>Information resulting from protocol machine state transitions
667is displayed using an informal set of ASCII strings called
668.Lk decode.html#kiss "kiss codes" .
669The original purpose was for kiss-o'-death (KoD) packets
670sent by the server to advise the client of an unusual condition.
671They are now displayed, when appropriate,
672in the reference identifier field in various billboards.
673
674<h5 class="subsubsection">System Variables</h5>
675
676<p>The following system variables appear in the
677<code>readlist</code>
678billboard.
679Not all variables are displayed in some configurations.
680
681     <dl>
682<dt>Variable<dd>Description
683<br><dt><code>status</code><dd>.Lk decode.html#sys "system status word"
684<br><dt><code>version</code><dd>NTP software version and build time
685<br><dt><code>processor</code><dd>hardware platform and version
686<br><dt><code>system</code><dd>operating system and version
687<br><dt><code>leap</code><dd>leap warning indicator (0-3)
688<br><dt><code>stratum</code><dd>stratum (1-15)
689<br><dt><code>precision</code><dd>precision (log2 s)
690<br><dt><code>rootdelay</code><dd>total roundtrip delay to the primary reference clock
691<br><dt><code>rootdisp</code><dd>total dispersion to the primary reference clock
692<br><dt><code>refid</code><dd>reference id or
693.Lk decode.html#kiss "kiss code"
694<br><dt><code>reftime</code><dd>reference time
695<br><dt><code>clock</code><dd>date and time of day
696<br><dt><code>peer</code><dd>system peer association id
697<br><dt><code>tc</code><dd>time constant and poll exponent (log2 s) (3-17)
698<br><dt><code>mintc</code><dd>minimum time constant (log2 s) (3-10)
699<br><dt><code>offset</code><dd>combined offset of server relative to this host
700<br><dt><code>frequency</code><dd>frequency drift (PPM) relative to hardware clock
701<br><dt><code>sys_jitter</code><dd>combined system jitter
702<br><dt><code>clk_wander</code><dd>clock frequency wander (PPM)
703<br><dt><code>clk_jitter</code><dd>clock jitter
704<br><dt><code>tai</code><dd>TAI-UTC offset (s)
705<br><dt><code>leapsec</code><dd>NTP seconds when the next leap second is/was inserted
706<br><dt><code>expire</code><dd>NTP seconds when the NIST leapseconds file expires
707</dl>
708  The jitter and wander statistics are exponentially-weighted RMS averages.
709The system jitter is defined in the NTPv4 specification;
710the clock jitter statistic is computed by the clock discipline module.
711
712  <p>When the NTPv4 daemon is compiled with the OpenSSL software library,
713additional system variables are displayed,
714including some or all of the following,
715depending on the particular Autokey dance:
716     <dl>
717<dt>Variable<dd>Description
718<br><dt><code>host</code><dd>Autokey host name for this host
719<br><dt><code>ident</code><dd>Autokey group name for this host
720<br><dt><code>flags</code><dd>host flags  (see Autokey specification)
721<br><dt><code>digest</code><dd>OpenSSL message digest algorithm
722<br><dt><code>signature</code><dd>OpenSSL digest/signature scheme
723<br><dt><code>update</code><dd>NTP seconds at last signature update
724<br><dt><code>cert</code><dd>certificate subject, issuer and certificate flags
725<br><dt><code>until</code><dd>NTP seconds when the certificate expires
726</dl>
727
728<h5 class="subsubsection">Peer Variables</h5>
729
730<p>The following peer variables appear in the
731<code>readlist</code>
732billboard for each association.
733Not all variables are displayed in some configurations.
734
735     <dl>
736<dt>Variable<dd>Description
737<br><dt><code>associd</code><dd>association id
738<br><dt><code>status</code><dd>.Lk decode.html#peer "peer status word"
739<br><dt><code>srcadr</code><dd>source (remote) IP address
740<br><dt><code>srcport</code><dd>source (remote) port
741<br><dt><code>dstadr</code><dd>destination (local) IP address
742<br><dt><code>dstport</code><dd>destination (local) port
743<br><dt><code>leap</code><dd>leap indicator (0-3)
744<br><dt><code>stratum</code><dd>stratum (0-15)
745<br><dt><code>precision</code><dd>precision (log2 s)
746<br><dt><code>rootdelay</code><dd>total roundtrip delay to the primary reference clock
747<br><dt><code>rootdisp</code><dd>total root dispersion to the primary reference clock
748<br><dt><code>refid</code><dd>reference id or
749.Lk decode.html#kiss "kiss code"
750<br><dt><code>reftime</code><dd>reference time
751<br><dt><code>rec</code><dd>last packet received time
752<br><dt><code>reach</code><dd>reach register (octal)
753<br><dt><code>unreach</code><dd>unreach counter
754<br><dt><code>hmode</code><dd>host mode (1-6)
755<br><dt><code>pmode</code><dd>peer mode (1-5)
756<br><dt><code>hpoll</code><dd>host poll exponent (log2 s) (3-17)
757<br><dt><code>ppoll</code><dd>peer poll exponent (log2 s) (3-17)
758<br><dt><code>headway</code><dd>headway (see
759.Lk rate.html "Rate Management and the Kiss-o'-Death Packet" )
760<br><dt><code>flash</code><dd>.Lk decode.html#flash "flash status word"
761<br><dt><code>keyid</code><dd>symmetric key id
762<br><dt><code>offset</code><dd>filter offset
763<br><dt><code>delay</code><dd>filter delay
764<br><dt><code>dispersion</code><dd>filter dispersion
765<br><dt><code>jitter</code><dd>filter jitter
766<br><dt><code>bias</code><dd>unicast/broadcast bias
767<br><dt><code>xleave</code><dd>interleave delay (see
768.Lk xleave.html "NTP Interleaved Modes" )
769</dl>
770  The
771<code>bias</code>
772variable is calculated when the first broadcast packet is received
773after the calibration volley.
774It represents the offset of the broadcast subgraph relative to the
775unicast subgraph.
776The
777<code>xleave</code>
778variable appears only for the interleaved symmetric and interleaved modes.
779It represents the internal queuing, buffering and transmission delays
780for the preceding packet.
781
782  <p>When the NTPv4 daemon is compiled with the OpenSSL software library,
783additional peer variables are displayed, including the following:
784     <dl>
785<dt>Variable<dd>Description
786<br><dt><code>flags</code><dd>peer flags (see Autokey specification)
787<br><dt><code>host</code><dd>Autokey server name
788<br><dt><code>flags</code><dd>peer flags (see Autokey specification)
789<br><dt><code>signature</code><dd>OpenSSL digest/signature scheme
790<br><dt><code>initsequence</code><dd>initial key id
791<br><dt><code>initkey</code><dd>initial key index
792<br><dt><code>timestamp</code><dd>Autokey signature timestamp
793<br><dt><code>ident</code><dd>Autokey group name for this association
794</dl>
795
796<h5 class="subsubsection">Clock Variables</h5>
797
798<p>The following clock variables appear in the
799<code>clocklist</code>
800billboard for each association with a reference clock.
801Not all variables are displayed in some configurations.
802     <dl>
803<dt>Variable<dd>Description
804<br><dt><code>associd</code><dd>association id
805<br><dt><code>status</code><dd>.Lk decode.html#clock "clock status word"
806<br><dt><code>device</code><dd>device description
807<br><dt><code>timecode</code><dd>ASCII time code string (specific to device)
808<br><dt><code>poll</code><dd>poll messages sent
809<br><dt><code>noreply</code><dd>no reply
810<br><dt><code>badformat</code><dd>bad format
811<br><dt><code>baddata</code><dd>bad date or time
812<br><dt><code>fudgetime1</code><dd>fudge time 1
813<br><dt><code>fudgetime2</code><dd>fudge time 2
814<br><dt><code>stratum</code><dd>driver stratum
815<br><dt><code>refid</code><dd>driver reference id
816<br><dt><code>flags</code><dd>driver flags
817</dl>
818
819  <p>This section was generated by <strong>AutoGen</strong>,
820using the <code>agtexi-cmd</code> template and the option descriptions for the <code>ntpq</code> program.
821This software is released under the NTP license, &lt;http://ntp.org/license&gt;.
822
823<ul class="menu">
824<li><a accesskey="1" href="#ntpq-usage">ntpq usage</a>:                   ntpq help/usage (<span class="option">--help</span>)
825<li><a accesskey="2" href="#ntpq-ipv4">ntpq ipv4</a>:                    ipv4 option (-4)
826<li><a accesskey="3" href="#ntpq-ipv6">ntpq ipv6</a>:                    ipv6 option (-6)
827<li><a accesskey="4" href="#ntpq-command">ntpq command</a>:                 command option (-c)
828<li><a accesskey="5" href="#ntpq-interactive">ntpq interactive</a>:             interactive option (-i)
829<li><a accesskey="6" href="#ntpq-numeric">ntpq numeric</a>:                 numeric option (-n)
830<li><a accesskey="7" href="#ntpq-old_002drv">ntpq old-rv</a>:                  old-rv option
831<li><a accesskey="8" href="#ntpq-peers">ntpq peers</a>:                   peers option (-p)
832<li><a accesskey="9" href="#ntpq-refid">ntpq refid</a>:                   refid option (-r)
833<li><a href="#ntpq-wide">ntpq wide</a>:                    wide option (-w)
834<li><a href="#ntpq-config">ntpq config</a>:                  presetting/configuring ntpq
835<li><a href="#ntpq-exit-status">ntpq exit status</a>:             exit status
836</ul>
837
838<div class="node">
839<p><hr>
840<a name="ntpq-usage"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-ipv4">ntpq ipv4</a>,
841Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
842<br>
843</div>
844
845<h4 class="subsection">ntpq help/usage (<span class="option">--help</span>)</h4>
846
847<p><a name="index-ntpq-help-3"></a>
848This is the automatically generated usage text for ntpq.
849
850  <p>The text printed is the same whether selected with the <code>help</code> option
851(<span class="option">--help</span>) or the <code>more-help</code> option (<span class="option">--more-help</span>).  <code>more-help</code> will print
852the usage text by passing it through a pager program.
853<code>more-help</code> is disabled on platforms without a working
854<code>fork(2)</code> function.  The <code>PAGER</code> environment variable is
855used to select the program, defaulting to <span class="file">more</span>.  Both will exit
856with a status code of 0.
857
858<pre class="example">ntpq - standard NTP query program - Ver. 4.2.8p11
859Usage:  ntpq [ -&lt;flag&gt; [&lt;val&gt;] | --&lt;name&gt;[{=| }&lt;val&gt;] ]... [ host ...]
860  Flg Arg Option-Name    Description
861   -4 no  ipv4           Force IPv4 name resolution
862                                - prohibits the option 'ipv6'
863   -6 no  ipv6           Force IPv6 name resolution
864                                - prohibits the option 'ipv4'
865   -c Str command        run a command and exit
866                                - may appear multiple times
867   -d no  debug-level    Increase debug verbosity level
868                                - may appear multiple times
869   -D Num set-debug-level Set the debug verbosity level
870                                - may appear multiple times
871   -i no  interactive    Force ntpq to operate in interactive mode
872                                - prohibits these options:
873                                command
874                                peers
875   -n no  numeric        numeric host addresses
876      no  old-rv         Always output status line with readvar
877   -p no  peers          Print a list of the peers
878                                - prohibits the option 'interactive'
879   -r KWd refid          Set default display type for S2+ refids
880   -w no  wide           Display the full 'remote' value
881      opt version        output version information and exit
882   -? no  help           display extended usage information and exit
883   -! no  more-help      extended usage information passed thru pager
884   -&gt; opt save-opts      save the option state to a config file
885   -&lt; Str load-opts      load options from a config file
886                                - disabled as '--no-load-opts'
887                                - may appear multiple times
888
889Options are specified by doubled hyphens and their name or by a single
890hyphen and the flag character.
891
892The following option preset mechanisms are supported:
893 - reading file $HOME/.ntprc
894 - reading file ./.ntprc
895 - examining environment variables named NTPQ_*
896
897The valid "refid" option keywords are:
898  hash ipv4
899  or an integer from 0 through 1
900
901Please send bug reports to:  &lt;http://bugs.ntp.org, bugs@ntp.org&gt;
902</pre>
903  <div class="node">
904<p><hr>
905<a name="ntpq-ipv4"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-ipv6">ntpq ipv6</a>,
906Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-usage">ntpq usage</a>,
907Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
908<br>
909</div>
910
911<h4 class="subsection">ipv4 option (-4)</h4>
912
913<p><a name="index-ntpq_002dipv4-4"></a>
914This is the &ldquo;force ipv4 name resolution&rdquo; option.
915
916<p class="noindent">This option has some usage constraints.  It:
917     <ul>
918<li>must not appear in combination with any of the following options:
919ipv6.
920</ul>
921
922  <p>Force resolution of following host names on the command line
923to the IPv4 namespace.
924<div class="node">
925<p><hr>
926<a name="ntpq-ipv6"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-command">ntpq command</a>,
927Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-ipv4">ntpq ipv4</a>,
928Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
929<br>
930</div>
931
932<h4 class="subsection">ipv6 option (-6)</h4>
933
934<p><a name="index-ntpq_002dipv6-5"></a>
935This is the &ldquo;force ipv6 name resolution&rdquo; option.
936
937<p class="noindent">This option has some usage constraints.  It:
938     <ul>
939<li>must not appear in combination with any of the following options:
940ipv4.
941</ul>
942
943  <p>Force resolution of following host names on the command line
944to the IPv6 namespace.
945<div class="node">
946<p><hr>
947<a name="ntpq-command"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-interactive">ntpq interactive</a>,
948Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-ipv6">ntpq ipv6</a>,
949Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
950<br>
951</div>
952
953<h4 class="subsection">command option (-c)</h4>
954
955<p><a name="index-ntpq_002dcommand-6"></a>
956This is the &ldquo;run a command and exit&rdquo; option.
957This option takes a string argument <span class="file">cmd</span>.
958
959<p class="noindent">This option has some usage constraints.  It:
960     <ul>
961<li>may appear an unlimited number of times.
962</ul>
963
964  <p>The following argument is interpreted as an interactive format command
965and is added to the list of commands to be executed on the specified
966host(s).
967<div class="node">
968<p><hr>
969<a name="ntpq-interactive"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-numeric">ntpq numeric</a>,
970Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-command">ntpq command</a>,
971Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
972<br>
973</div>
974
975<h4 class="subsection">interactive option (-i)</h4>
976
977<p><a name="index-ntpq_002dinteractive-7"></a>
978This is the &ldquo;force ntpq to operate in interactive mode&rdquo; option.
979
980<p class="noindent">This option has some usage constraints.  It:
981     <ul>
982<li>must not appear in combination with any of the following options:
983command, peers.
984</ul>
985
986  <p>Force <code>ntpq</code> to operate in interactive mode.
987Prompts will be written to the standard output and
988commands read from the standard input.
989<div class="node">
990<p><hr>
991<a name="ntpq-numeric"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-old_002drv">ntpq old-rv</a>,
992Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-interactive">ntpq interactive</a>,
993Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
994<br>
995</div>
996
997<h4 class="subsection">numeric option (-n)</h4>
998
999<p><a name="index-ntpq_002dnumeric-8"></a>
1000This is the &ldquo;numeric host addresses&rdquo; option.
1001Output all host addresses in dotted-quad numeric format rather than
1002converting to the canonical host names.
1003<div class="node">
1004<p><hr>
1005<a name="ntpq-old_002drv"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-peers">ntpq peers</a>,
1006Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-numeric">ntpq numeric</a>,
1007Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1008<br>
1009</div>
1010
1011<h4 class="subsection">old-rv option</h4>
1012
1013<p><a name="index-ntpq_002dold_002drv-9"></a>
1014This is the &ldquo;always output status line with readvar&rdquo; option.
1015By default, <code>ntpq</code> now suppresses the <code>associd=...</code>
1016line that precedes the output of <code>readvar</code>
1017(alias <code>rv</code>) when a single variable is requested, such as
1018<code>ntpq -c "rv 0 offset"</code>.
1019This option causes <code>ntpq</code> to include both lines of output
1020for a single-variable <code>readvar</code>.
1021Using an environment variable to
1022preset this option in a script will enable both older and
1023newer <code>ntpq</code> to behave identically in this regard.
1024<div class="node">
1025<p><hr>
1026<a name="ntpq-peers"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-refid">ntpq refid</a>,
1027Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-old_002drv">ntpq old-rv</a>,
1028Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1029<br>
1030</div>
1031
1032<h4 class="subsection">peers option (-p)</h4>
1033
1034<p><a name="index-ntpq_002dpeers-10"></a>
1035This is the &ldquo;print a list of the peers&rdquo; option.
1036
1037<p class="noindent">This option has some usage constraints.  It:
1038     <ul>
1039<li>must not appear in combination with any of the following options:
1040interactive.
1041</ul>
1042
1043  <p>Print a list of the peers known to the server as well as a summary
1044of their state. This is equivalent to the 'peers' interactive command.
1045<div class="node">
1046<p><hr>
1047<a name="ntpq-refid"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-wide">ntpq wide</a>,
1048Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-peers">ntpq peers</a>,
1049Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1050<br>
1051</div>
1052
1053<h4 class="subsection">refid option (-r)</h4>
1054
1055<p><a name="index-ntpq_002drefid-11"></a>
1056This is the &ldquo;set default display type for s2+ refids&rdquo; option.
1057This option takes a keyword argument.
1058
1059<p class="noindent">This option has some usage constraints.  It:
1060     <ul>
1061<li>This option takes a keyword as its argument.
1062The argument sets an enumeration value that can be tested by comparing the option value macro (OPT_VALUE_REFID).
1063The available keywords are:
1064     <pre class="example">             hash ipv4
1065    </pre>
1066     <p>or their numeric equivalent.</ul>
1067
1068  <p>Set the default display format for S2+ refids.
1069<div class="node">
1070<p><hr>
1071<a name="ntpq-wide"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-config">ntpq config</a>,
1072Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-refid">ntpq refid</a>,
1073Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1074<br>
1075</div>
1076
1077<h4 class="subsection">wide option (-w)</h4>
1078
1079<p><a name="index-ntpq_002dwide-12"></a>
1080This is the &ldquo;display the full 'remote' value&rdquo; option.
1081Display the full value of the 'remote' value.  If this requires
1082more than 15 characters, display the full value, emit a newline,
1083and continue the data display properly indented on the next line.
1084
1085<div class="node">
1086<p><hr>
1087<a name="ntpq-config"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#ntpq-exit-status">ntpq exit status</a>,
1088Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-wide">ntpq wide</a>,
1089Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1090<br>
1091</div>
1092
1093<h4 class="subsection">presetting/configuring ntpq</h4>
1094
1095<p>Any option that is not marked as <i>not presettable</i> may be preset by
1096loading values from configuration ("rc" or "ini") files, and values from environment variables named <code>NTPQ</code> and <code>NTPQ_&lt;OPTION_NAME&gt;</code>.  <code>&lt;OPTION_NAME&gt;</code> must be one of
1097the options listed above in upper case and segmented with underscores.
1098The <code>NTPQ</code> variable will be tokenized and parsed like
1099the command line.  The remaining variables are tested for existence and their
1100values are treated like option arguments.
1101
1102<p class="noindent"><code>libopts</code> will search in 2 places for configuration files:
1103     <ul>
1104<li>$HOME
1105<li>$PWD
1106</ul>
1107  The environment variables <code>HOME</code>, and <code>PWD</code>
1108are expanded and replaced when <span class="file">ntpq</span> runs.
1109For any of these that are plain files, they are simply processed.
1110For any that are directories, then a file named <span class="file">.ntprc</span> is searched for
1111within that directory and processed.
1112
1113  <p>Configuration files may be in a wide variety of formats.
1114The basic format is an option name followed by a value (argument) on the
1115same line.  Values may be separated from the option name with a colon,
1116equal sign or simply white space.  Values may be continued across multiple
1117lines by escaping the newline with a backslash.
1118
1119  <p>Multiple programs may also share the same initialization file.
1120Common options are collected at the top, followed by program specific
1121segments.  The segments are separated by lines like:
1122<pre class="example">    [NTPQ]
1123</pre>
1124  <p class="noindent">or by
1125<pre class="example">    &lt;?program ntpq&gt;
1126</pre>
1127  <p class="noindent">Do not mix these styles within one configuration file.
1128
1129  <p>Compound values and carefully constructed string values may also be
1130specified using XML syntax:
1131<pre class="example">    &lt;option-name&gt;
1132       &lt;sub-opt&gt;...&amp;lt;...&amp;gt;...&lt;/sub-opt&gt;
1133    &lt;/option-name&gt;
1134</pre>
1135  <p class="noindent">yielding an <code>option-name.sub-opt</code> string value of
1136<pre class="example">    "...&lt;...&gt;..."
1137</pre>
1138  <p><code>AutoOpts</code> does not track suboptions.  You simply note that it is a
1139hierarchicly valued option.  <code>AutoOpts</code> does provide a means for searching
1140the associated name/value pair list (see: optionFindValue).
1141
1142  <p>The command line options relating to configuration and/or usage help are:
1143
1144<h5 class="subsubheading">version (-)</h5>
1145
1146<p>Print the program version to standard out, optionally with licensing
1147information, then exit 0.  The optional argument specifies how much licensing
1148detail to provide.  The default is to print just the version.  The licensing infomation may be selected with an option argument.
1149Only the first letter of the argument is examined:
1150
1151     <dl>
1152<dt><span class="samp">version</span><dd>Only print the version.  This is the default.
1153<br><dt><span class="samp">copyright</span><dd>Name the copyright usage licensing terms.
1154<br><dt><span class="samp">verbose</span><dd>Print the full copyright usage licensing terms.
1155</dl>
1156
1157<div class="node">
1158<p><hr>
1159<a name="ntpq-exit-status"></a>Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-config">ntpq config</a>,
1160Up:&nbsp;<a rel="up" accesskey="u" href="#ntpq-Invocation">ntpq Invocation</a>
1161<br>
1162</div>
1163
1164<h4 class="subsection">ntpq exit status</h4>
1165
1166<p>One of the following exit values will be returned:
1167     <dl>
1168<dt><span class="samp">0 (EXIT_SUCCESS)</span><dd>Successful program execution.
1169<br><dt><span class="samp">1 (EXIT_FAILURE)</span><dd>The operation failed or the command syntax was not valid.
1170<br><dt><span class="samp">66 (EX_NOINPUT)</span><dd>A specified configuration file could not be loaded.
1171<br><dt><span class="samp">70 (EX_SOFTWARE)</span><dd>libopts had an internal operational error.  Please report
1172it to autogen-users@lists.sourceforge.net.  Thank you.
1173</dl>
1174
1175<div class="node">
1176<p><hr>
1177<a name="Usage"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Internal-Commands">Internal Commands</a>,
1178Previous:&nbsp;<a rel="previous" accesskey="p" href="#ntpq-Description">ntpq Description</a>,
1179Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1180<br>
1181</div>
1182
1183<!-- node-name,  next,  previous,  up -->
1184<h3 class="section">Usage</h3>
1185
1186<p><table summary=""><tr align="left"><th valign="top" width="23%">What </th><th valign="top" width="23%">Default </th><th valign="top" width="5%">Flag </th><th valign="top" width="15%">Option
1187<br></th></tr><tr align="left"><td valign="top" width="23%">configuration file
1188</td><td valign="top" width="23%"><code>/etc/ntp.conf</code>
1189</td><td valign="top" width="5%"><code>-c</code>
1190</td><td valign="top" width="15%"><code>conffile</code>
1191<br></td></tr><tr align="left"><td valign="top" width="23%">frequency file
1192</td><td valign="top" width="23%">none
1193</td><td valign="top" width="5%"><code>-f</code>
1194</td><td valign="top" width="15%"><code>driftfile</code>
1195<br></td></tr><tr align="left"><td valign="top" width="23%">leapseconds file
1196</td><td valign="top" width="23%">none
1197</td><td valign="top" width="5%">
1198</td><td valign="top" width="15%"><code>leapfile</code>
1199<br></td></tr><tr align="left"><td valign="top" width="23%">process ID file
1200</td><td valign="top" width="23%">none
1201</td><td valign="top" width="5%"><code>-p</code>
1202</td><td valign="top" width="15%"><code>pidfile</code>
1203<br></td></tr><tr align="left"><td valign="top" width="23%">log file
1204</td><td valign="top" width="23%">system log
1205</td><td valign="top" width="5%"><code>-l</code>
1206</td><td valign="top" width="15%"><code>logfile</code>
1207<br></td></tr><tr align="left"><td valign="top" width="23%">include file
1208</td><td valign="top" width="23%">none
1209</td><td valign="top" width="5%">none
1210</td><td valign="top" width="15%"><code>includefile</code>
1211<br></td></tr><tr align="left"><td valign="top" width="23%">statistics path
1212</td><td valign="top" width="23%"><code>/var/NTP</code>
1213</td><td valign="top" width="5%"><code>-s</code>
1214</td><td valign="top" width="15%"><code>statsdir</code>
1215<br></td></tr><tr align="left"><td valign="top" width="23%">keys path
1216</td><td valign="top" width="23%"><code>/usr/local/etc</code>
1217</td><td valign="top" width="5%"><code>-k</code>
1218</td><td valign="top" width="15%"><code>keysdir</code>
1219<br></td></tr></table>
1220
1221<div class="node">
1222<p><hr>
1223<a name="Internal-Commands"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Control-Message-Commands">Control Message Commands</a>,
1224Previous:&nbsp;<a rel="previous" accesskey="p" href="#Usage">Usage</a>,
1225Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1226<br>
1227</div>
1228
1229<!-- node-name,  next,  previous,  up -->
1230<h3 class="section">Internal Commands</h3>
1231
1232<p>Interactive format commands consist of a keyword followed by zero to four arguments.  Only enough characters of the full keyword to uniquely identify the command need be typed.  The output of a command is normally sent to the standard output, but optionally the output of individual commands may be sent to a file by appending a <code>&gt;</code>, followed by a file name, to the command line.  A number of interactive format commands are executed entirely within the <code>ntpq</code> program itself and do not result in NTP mode-6 requests being sent to a server.  These are described following.
1233
1234     <dl>
1235<dt><code><a name="help"></a> ? [</code><kbd>command_keyword</kbd><code>]</code><dt><code>help [</code><kbd>command_keyword</kbd><code>]</code><dd>A <code>?</code> by itself will print a list of all the command keywords known to <code>ntpq</code>.  A <code>?</code> followed by a command keyword will print function and usage information about the command.
1236
1237     <br><dt><code><a name="addvars"></a> &gt;addvars </code><kbd>name</kbd><code> [ = </code><kbd>value</kbd><code>] [...]</code><dt><code>rmvars </code><kbd>name</kbd><code> [...]</code><dt><code>clearvars&lt;/dt&gt;</code><dd>The arguments to these commands consist of a list of items of the form
1238<kbd>name</kbd><code> = </code><kbd>value</kbd>, where the <code>= </code><kbd>value</kbd> is ignored,
1239and can be omitted in read requests.
1240<code>ntpq</code> maintains an internal list in which data to be included
1241in control messages can be assembled, and sent using the <code>readlist</code>
1242and <code>writelist</code> commands described below.
1243The <code>addvars</code> command allows variables and optional values
1244to be added to the list.
1245If more than one variable is to be added
1246the list should be comma-separated and not contain white space.
1247The <code>rmvars</code> command can be used to remove individual variables
1248from the list,
1249while the <code>clearlist</code> command removes all variables from the list.
1250
1251     <br><dt><code><a name="cooked"></a> cooked</code><dd>Display server messages in prettyprint format.
1252
1253     <br><dt><code><a name="debug"></a> debug more | less | off</code><dd>Turns internal query program debugging on and off.
1254
1255     <br><dt><code><a name="delay"></a> delay </code><kbd>milliseconds</kbd><dd>Specify a time interval to be added to timestamps included in requests which require authentication.  This is used to enable (unreliable) server reconfiguration over long delay network paths or between machines whose clocks are unsynchronized.  Actually the server does not now require timestamps in authenticated requests, so this command may be obsolete.
1256
1257     <br><dt><code><a name="host"></a> host </code><kbd>name</kbd><dd>Set the host to which future queries will be sent.
1258The name may be either a DNS name or a numeric address.
1259
1260     <br><dt><code><a name="hostnames"></a> hostnames [yes | no]</code><dd>If <code>yes</code> is specified, host names are printed in information displays.
1261If <code>no</code> is specified, numeric addresses are printed instead.
1262The default is <code>yes</code>,
1263unless modified using the command line <code>-n</code> switch.
1264
1265     <br><dt><code><a name="keyid"></a> keyid </code><kbd>keyid</kbd><dd>This command specifies the key number to be used
1266to authenticate configuration requests.
1267This must correspond to a key ID configured in <code>ntp.conf</code> for this purpose.
1268
1269     <br><dt><code><a name="keytype"></a> keytype</code><dd>Specify the digest algorithm to use for authenticated requests,
1270with default <code>MD5</code>.
1271If the OpenSSL library is installed,
1272digest can be be any message digest algorithm supported by the library.
1273The current selections are: <code>AES128CMAC</code>, <code>MD2</code>, <code>MD4</code>, <code>MD5</code>, <code>MDC2</code>, <code>RIPEMD160</code>, <code>SHA</code> and <code>SHA1</code>.
1274
1275     <br><dt><code><a name="ntpversion"></a> ntpversion 1 | 2 | 3 | 4</code><dd>Sets the NTP version number which <code>ntpq</code> claims in packets.
1276Defaults to 2.
1277Note that mode-6 control messages (and modes, for that matter)
1278didn't exist in NTP version 1.
1279
1280     <br><dt><code><a name="passwd"></a> passwd</code><dd>This command prompts for a password to authenticate requests.
1281The password must correspond to the key ID configured in <code>ntp.conf</code> for this purpose.
1282
1283     <br><dt><code><a name="quit"></a> quit</code><dd>Exit <code>ntpq</code>.
1284
1285     <br><dt><code><a name="raw"></a> raw</code><dd>Display server messages as received and without reformatting.
1286
1287     <br><dt><code><a name="timeout"></a> timeout </code><kbd>milliseconds</kbd><dd>Specify a timeout period for responses to server queries.
1288The default is about 5000 milliseconds.
1289Note that since <code>ntpq</code> retries each query once after a timeout
1290the total waiting time for a timeout will be twice the timeout value set.
1291
1292  </dl>
1293
1294<div class="node">
1295<p><hr>
1296<a name="Control-Message-Commands"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Status-Words-and-Kiss-Codes">Status Words and Kiss Codes</a>,
1297Previous:&nbsp;<a rel="previous" accesskey="p" href="#Internal-Commands">Internal Commands</a>,
1298Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1299<br>
1300</div>
1301
1302<!-- node-name,  next,  previous,  up -->
1303<h3 class="section">Control Message Commands</h3>
1304
1305<p>Association IDs are used to identify system, peer and clock variables.
1306System variables are assigned an association ID of zero and system name space,
1307while each association is assigned a nonzero association ID and peer namespace.
1308Most control commands send a single mode-6 message to the server
1309and expect a single response message.
1310The exceptions are the <code>peers</code> command,
1311which sends a series of messages,
1312and the <code>mreadlist</code> and <code>mreadvar</code> commands,
1313which iterate over a range of associations.
1314
1315  <p><a name="as"></a>
1316     <dl>
1317<dt><code>associations</code><dd>Display a list of mobilized associations in the form:
1318<br>
1319<code>ind assid status conf reach auth condition last_event cnt</code>
1320
1321     <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="40%">Description
1322
1323     <p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>ind</code>
1324</td><td valign="top" width="40%">index on this list
1325
1326     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>assid</code>
1327</td><td valign="top" width="40%">association ID
1328
1329     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>status</code>
1330</td><td valign="top" width="40%"><a href="decode.html#peer">peer status word</a>
1331
1332     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>conf</code>
1333</td><td valign="top" width="40%"><code>yes</code>: persistent, <code>no</code>: ephemeral
1334
1335     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>reach</code>
1336</td><td valign="top" width="40%"><code>yes</code>: reachable, <code>no</code>: unreachable
1337
1338     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>auth</code>
1339</td><td valign="top" width="40%"><code>ok</code>, <code>yes</code>, <code>bad</code> and <code>none</code>
1340
1341     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>condition</code>
1342</td><td valign="top" width="40%">selection status (see the <code>select</code> field of the <a href="decode.html#peer">peer status word</a>)
1343
1344     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>last_event</code>
1345</td><td valign="top" width="40%">event report (see the <code>event</code> field of the <a href="decode.html#peer">peer status word</a>)
1346
1347     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>cnt</code>
1348event count (see the <code>count</code> field of the <a href="decode.html#peer">peer status word</a>)
1349
1350     <br></td></tr></table>
1351
1352     <br><dt><code><a name="cv"></a> clockvar </code><kbd>assocID</kbd><code> [</code><kbd>name</kbd><code> [ = </code><kbd>value</kbd><code> [...]] [...]]</code><dt><code>cv </code><kbd>assocID</kbd><code> [</code><kbd>name</kbd><code> [ = </code><kbd>value</kbd><code> [...] ][...]]</code><dd>Display a list of <a href="#clock">clock variables</a> for those associations supporting a reference clock.
1353
1354     <br><dt><code><a name="_003aconfig"></a> :config [...]</code><dd>Send the remainder of the command line, including whitespace, to the server
1355as a run-time configuration command in the same format
1356as the configuration file.
1357This command is experimental until further notice and clarification.
1358Authentication is of course required.
1359
1360     <br><dt><code><a name="config_002dfrom_002dfile"></a> config-from-file </code><kbd>filename</kbd><dd>Send the each line of <kbd>filename</kbd> to the server as
1361run-time configuration commands in the same format as the configuration file.
1362This command is experimental until further notice and clarification.
1363Authentication is required.
1364
1365     <br><dt><code><a name="ifstats"></a> ifstats</code><dd>Display statistics for each local network address.
1366Authentication is required.
1367
1368     <br><dt><code><a name="iostats"></a> iostats</code><dd>Display network and reference clock I/O statistics.
1369
1370     <br><dt><code><a name="kerninfo"></a> kerninfo</code><dd>Display kernel loop and PPS statistics.
1371As with other ntpq output, times are in milliseconds.
1372The precision value displayed is in milliseconds as well,
1373unlike the precision system variable.
1374
1375     <br><dt><code><a name="lassoc"></a> lassociations</code><dd>Perform the same function as the associations command,
1376except display mobilized and unmobilized associations.
1377
1378     <br><dt><code><a name="monstats"></a> monstats</code><dd>Display monitor facility statistics.
1379
1380     <br><dt><code><a name="mrulist"></a> mrulist [limited | kod | mincount=</code><kbd>count</kbd><code> | laddr=</code><kbd>localaddr</kbd><code> | sort=</code><kbd>sortorder</kbd><code> | resany=</code><kbd>hexmask</kbd><code> | resall=</code><kbd>hexmask</kbd><code>]</code><dd>Obtain and print traffic counts collected and maintained by
1381the monitor facility.
1382With the exception of <code>sort=</code><kbd>sortorder</kbd>,
1383the options filter the list returned by <code>ntpd</code>.
1384The <code>limited</code> and <code>kod</code> options return only entries
1385representing client addresses from which the last packet received
1386triggered either discarding or a KoD response.
1387The <code>mincount=</code><kbd>count</kbd> option filters entries representing
1388less than <kbd>count</kbd> packets.
1389The <code>laddr=</code><kbd>localaddr</kbd> option filters entries for packets
1390received on any local address other than <kbd>localaddr</kbd>.
1391<code>resany=</code><kbd>hexmask</kbd> and <code>resall=</code><kbd>hexmask</kbd>
1392filter entries containing none or less than all, respectively,
1393of the bits in <kbd>hexmask</kbd>, which must begin with <code>0x</code>.
1394<br>
1395The <kbd>sortorder</kbd> defaults to <code>lstint</code> and may be any of
1396<code>addr</code>, <code>count</code>, <code>avgint</code>, <code>lstint</code>, or
1397any of those preceded by a minus sign (hyphen) to reverse the sort order.
1398The output columns are:
1399
1400     <p><table summary=""><tr align="left"><th valign="top" width="10%">Column </th><th valign="top" width="40%">Description
1401
1402     <p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>lstint</code>
1403</td><td valign="top" width="40%">
1404Interval in s between the receipt of the most recent packet from this
1405address and the completion of the retrieval of the MRU list by <code>ntpq</code>
1406
1407     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>avgint</code>
1408</td><td valign="top" width="40%">
1409Average interval in s between packets from this address.
1410
1411     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rstr</code>
1412</td><td valign="top" width="40%">
1413Restriction flags associated with this address.
1414Most are copied unchanged from the matching <code>restrict</code> command,
1415however 0x400 (kod) and 0x20 (limited) flags are cleared unless
1416the last packet from this address triggered a rate control response.
1417
1418     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>r</code>
1419</td><td valign="top" width="40%">
1420Rate control indicator, either a period, <code>L</code> or <code>K</code> for
1421no rate control response, rate limiting by discarding, or
1422rate limiting with a KoD response, respectively.
1423
1424     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>m</code>
1425</td><td valign="top" width="40%">
1426Packet mode.
1427<br></td></tr><tr align="left"><td valign="top" width="10%"><code>v</code>
1428</td><td valign="top" width="40%">
1429Packet version number.
1430
1431     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>count</code>
1432</td><td valign="top" width="40%">
1433Packets received from this address.
1434
1435     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rport</code>
1436</td><td valign="top" width="40%">
1437Source port of last packet from this address.
1438
1439     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>remote address</code>
1440</td><td valign="top" width="40%">
1441DNS name, numeric address, or address followed by claimed DNS name which
1442could not be verified in parentheses.
1443
1444     <br></td></tr></table>
1445
1446     <br><dt><code><a name="mreadvar"></a> mreadvar </code><kbd>assocID</kbd> <kbd>assocID</kbd><code> [ </code><kbd>variable_name</kbd><code> [ = </code><kbd>value</kbd><code>[ ... ]</code><dt><code><a name="mrv"></a> mrv </code><kbd>assocID</kbd> <kbd>assocID</kbd><code> [ </code><kbd>variable_name</kbd><code> [ = </code><kbd>value</kbd><code>[ ... ]</code><dd>Perform the same function as the <code>readvar</code> command,
1447except for a range of association IDs.
1448This range is determined from the association list cached by
1449the most recent <code>associations</code> command.
1450
1451     <br><dt><code><a name="passoc"></a> passociations</code><dd>Perform the same function as the <code>associations command</code>, except that
1452it uses previously stored data rather than making a new query.
1453
1454     <br><dt><code><a name="pe"></a> peers</code><dd>Display a list of peers in the form:
1455<br>
1456<code>[tally]remote refid st t when pool reach delay offset jitter</code>
1457
1458     <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1459<br></th></tr><tr align="left"><td valign="top" width="10%"><code>[tally]</code>
1460</td><td valign="top" width="20%">
1461single-character code indicating current value of the <code>select</code> field
1462of the <a href="decode.html#peer">peer status word</a>.
1463
1464     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>remote</code>
1465</td><td valign="top" width="20%">
1466host name (or IP number) of peer
1467
1468     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>refid</code>
1469</td><td valign="top" width="20%">
1470association ID or <a href="decode.html#kiss">kiss code</a>.
1471
1472     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>st</code>
1473</td><td valign="top" width="20%">
1474stratum
1475
1476     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>t</code>
1477</td><td valign="top" width="20%">
1478<code>u</code>: unicast or manycast client,
1479<code>b</code>: broadcast or multicast client,
1480<code>l</code>: local (reference clock),
1481<code>s</code>: symmetric (peer),
1482<code>A</code>: manycast server,
1483<code>B</code>: broadcast server,
1484<code>M</code>: multicast server.
1485
1486     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>when</code>
1487</td><td valign="top" width="20%">
1488sec/min/hr since last received packet
1489
1490     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>poll</code>
1491</td><td valign="top" width="20%">
1492poll interval (log(2) s)
1493
1494     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>reach</code>
1495</td><td valign="top" width="20%">
1496reach shift register (octal)
1497
1498     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>delay</code>
1499</td><td valign="top" width="20%">
1500roundtrip delay
1501
1502     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>offset</code>
1503</td><td valign="top" width="20%">
1504offset of server relative to this host
1505
1506     <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>jitter</code>
1507</td><td valign="top" width="20%">
1508jitter
1509
1510     <br></td></tr></table>
1511
1512     <br><dt><code><a name="rv"></a> readvar </code><kbd>assocID</kbd> <kbd>name</kbd><code> [ = </code><kbd>value</kbd><code> ] [,...]</code><dt><code>rv </code><kbd>assocID</kbd><code> [ </code><kbd>name</kbd><code> ] [,...]</code><dd>Display the specified variables.
1513If <kbd>assocID</kbd> is zero,
1514the variables are from the <a href="#system">system variables</a> name space,
1515otherwise they are from the <a href="#peer">peer variables</a> name space.
1516The <kbd>assocID</kbd> is required, as the same name can occur in both spaces.
1517If no <kbd>name</kbd> is included,
1518all operative variables in the name space are displayed.
1519In this case only, if the <kbd>assocID</kbd> is omitted, it is assumed zero.
1520Multiple names are specified with comma separators and without whitespace.
1521Note that time values are represented in milliseconds and
1522frequency values in parts-per-million (PPM).
1523Some NTP timestamps are represented in the format YYYYMMDDTTTT,
1524where YYYY is the year, MM the month of year, DD the day of month and
1525TTTT the time of day.
1526
1527     <br><dt><code><a name="saveconfig"></a> saveconfig </code><kbd>filename</kbd><dd>Write the current configuration, including any runtime modifications
1528given with <code>:config</code> or <code>config-from-file</code>,
1529to the ntpd host's file <kbd>filename</kbd>.
1530This command will be rejected by the server unless
1531<a href="miscopt.html#saveconfigdir">saveconfigdir</a>
1532appears in the <code>ntpd</code> configuration file.
1533<kbd>filename</kbd> can use <code>strftime()</code> format specifiers
1534to substitute the current date and time, for example,
1535<code>saveconfig ntp-%Y%m%d-%H%M%S.conf</code>.
1536The filename used is stored in system variable <code>savedconfig</code>.
1537Authentication is required.
1538
1539     <br><dt><code><a name="writevar"></a> writevar </code><kbd>assocID</kbd> <kbd>name</kbd><code> = </code><kbd>value</kbd><code> [,...]</code><dd>Write the specified variables.
1540If the <kbd>assocID</kbd> is zero, the variables are from the
1541<a href="#system">system variables</a> name space, otherwise they are from the
1542<a href="#peer">peer variables</a> name	space.
1543The <kbd>assocID</kbd> is required,
1544as the same name can occur in both spaces.
1545
1546     <br><dt><code><a name="sysinfo"></a> sysinfo</code><dd>Display operational summary.
1547
1548     <br><dt><code><a name="sysstats"></a> sysstats</code><dd>Print statistics counters maintained in the protocol module.
1549
1550  </dl>
1551
1552<div class="node">
1553<p><hr>
1554<a name="Status-Words-and-Kiss-Codes"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#System-Variables">System Variables</a>,
1555Previous:&nbsp;<a rel="previous" accesskey="p" href="#Control-Message-Commands">Control Message Commands</a>,
1556Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1557<br>
1558</div>
1559
1560<!-- node-name,  next,  previous,  up -->
1561<h3 class="section">Status Words and Kiss Codes</h3>
1562
1563<p>The current state of the operating program is shown
1564in a set of status words maintained by the system
1565and each association separately.
1566These words are displayed in the <code>rv</code> and <code>as</code> commands
1567both in hexadecimal and decoded short tip strings.
1568The codes, tips and short explanations are on the
1569<a href="decode.html">Event Messages and Status Words</a> page.
1570The page also includes a list of system and peer messages,
1571the code for the latest of which is included in the status word.
1572
1573  <p>Information resulting from protocol machine state transitions
1574is displayed using an informal set of ASCII strings called
1575<a href="decode.html#kiss">kiss codes</a>.
1576The original purpose was for kiss-o'-death (KoD) packets sent
1577by the server to advise the client of an unusual condition.
1578They are now displayed, when appropriate,
1579in the reference identifier field in various billboards.
1580
1581<div class="node">
1582<p><hr>
1583<a name="System-Variables"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Peer-Variables">Peer Variables</a>,
1584Previous:&nbsp;<a rel="previous" accesskey="p" href="#Status-Words-and-Kiss-Codes">Status Words and Kiss Codes</a>,
1585Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1586<br>
1587</div>
1588
1589<!-- node-name,  next,  previous,  up -->
1590<h3 class="section">System Variables</h3>
1591
1592<p>The following system variables appear in the <code>rv</code> billboard.
1593Not all variables are displayed in some configurations.
1594
1595  <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1596
1597<p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>status</code>
1598</td><td valign="top" width="20%">
1599<a href="decode.html#sys">system status word</a>
1600
1601<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>version</code>
1602</td><td valign="top" width="20%">
1603NTP software version and build time
1604
1605<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>processor</code>
1606</td><td valign="top" width="20%">
1607hardware platform and version
1608
1609<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>system</code>
1610</td><td valign="top" width="20%">
1611operating system and version
1612
1613<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>leap</code>
1614</td><td valign="top" width="20%">
1615leap warning indicator (0-3)
1616
1617<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>stratum</code>
1618</td><td valign="top" width="20%">
1619stratum (1-15)
1620
1621<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>precision</code>
1622</td><td valign="top" width="20%">
1623precision (log(2) s)
1624
1625<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rootdelay</code>
1626</td><td valign="top" width="20%">
1627total roundtrip delay to the primary reference clock
1628
1629<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rootdisp</code>
1630</td><td valign="top" width="20%">
1631total dispersion to the primary reference clock
1632
1633<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>peer</code>
1634</td><td valign="top" width="20%">
1635system peer association ID
1636
1637<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>tc</code>
1638time constant and poll exponent (log(2) s) (3-17)
1639
1640  <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>mintc</code>
1641minimum time constant (log(2) s) (3-10)
1642
1643  <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>clock</code>
1644</td><td valign="top" width="20%">
1645date and time of day
1646
1647<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>refid</code>
1648reference ID or <a href="decode.html#kiss">kiss code</a>
1649
1650  <p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>reftime</code>
1651</td><td valign="top" width="20%">
1652reference time
1653
1654<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>offset</code>
1655</td><td valign="top" width="20%">
1656combined offset of server relative to this host
1657
1658<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>sys_jitter</code>
1659</td><td valign="top" width="20%">
1660combined system jitter
1661
1662<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>frequency</code>
1663</td><td valign="top" width="20%">
1664frequency offset (PPM) relative to hardware clock
1665
1666<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>clk_wander</code>
1667</td><td valign="top" width="20%">
1668clock frequency wander (PPM)
1669
1670<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>clk_jitter</code>
1671</td><td valign="top" width="20%">
1672clock jitter
1673
1674<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>tai</code>
1675</td><td valign="top" width="20%">
1676TAI-UTC offset (s)
1677
1678<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>leapsec</code>
1679</td><td valign="top" width="20%">
1680NTP seconds when the next leap second is/was inserted
1681
1682<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>expire</code>
1683</td><td valign="top" width="20%">
1684NTP seconds when the NIST leapseconds file expires
1685
1686  <br></td></tr></table>
1687
1688  <p>The jitter and wander statistics are exponentially-weighted RMS averages.
1689The system jitter is defined in the NTPv4 specification;
1690the clock jitter statistic is computed by the clock discipline module.
1691
1692  <p>When the NTPv4 daemon is compiled with the OpenSSL software library,
1693additional system variables are displayed, including some or all of the
1694following, depending on the particular Autokey dance:
1695
1696  <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1697
1698<p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>host</code>
1699</td><td valign="top" width="20%">
1700Autokey host name for this host
1701
1702<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>ident</code>
1703</td><td valign="top" width="20%">
1704Autokey group name for this host
1705
1706<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>flags</code>
1707</td><td valign="top" width="20%">
1708host flags  (see Autokey specification)
1709
1710<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>digest</code>
1711</td><td valign="top" width="20%">
1712OpenSSL message digest algorithm
1713
1714<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>signature</code>
1715</td><td valign="top" width="20%">
1716OpenSSL digest/signature scheme
1717
1718<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>update</code>
1719</td><td valign="top" width="20%">
1720NTP seconds at last signature update
1721
1722<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>cert</code>
1723</td><td valign="top" width="20%">
1724certificate subject, issuer and certificate flags
1725
1726<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>until</code>
1727</td><td valign="top" width="20%">
1728NTP seconds when the certificate expires
1729
1730  <br></td></tr></table>
1731
1732<div class="node">
1733<p><hr>
1734<a name="Peer-Variables"></a>Next:&nbsp;<a rel="next" accesskey="n" href="#Clock-Variables">Clock Variables</a>,
1735Previous:&nbsp;<a rel="previous" accesskey="p" href="#System-Variables">System Variables</a>,
1736Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1737<br>
1738</div>
1739
1740<!-- node-name,  next,  previous,  up -->
1741<h3 class="section">Peer Variables</h3>
1742
1743<p>The following peer variables appear in the <code>rv</code> billboard
1744for each association.
1745Not all variables are displayed in some configurations.
1746
1747  <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1748
1749<p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>associd</code>
1750</td><td valign="top" width="20%">
1751association ID
1752
1753<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>status</code>
1754</td><td valign="top" width="20%">
1755<a href="decode.html#peer">peer status word</a>
1756
1757<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>srcadr</code>
1758<br></td></tr><tr align="left"><td valign="top" width="10%"><code>srcport</code>
1759</td><td valign="top" width="20%">
1760source (remote) IP address and port
1761
1762<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>dstadr</code>
1763<br></td></tr><tr align="left"><td valign="top" width="10%"><code>dstport</code>
1764</td><td valign="top" width="20%">
1765destination (local) IP address and port
1766
1767<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>leap</code>
1768</td><td valign="top" width="20%">
1769leap indicator (0-3)
1770
1771<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>stratum</code>
1772</td><td valign="top" width="20%">
1773stratum (0-15)
1774
1775<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>precision</code>
1776</td><td valign="top" width="20%">
1777precision (log(2) s)
1778
1779<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rootdelay</code>
1780</td><td valign="top" width="20%">
1781total roundtrip delay to the primary reference clock
1782
1783<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>rootdisp</code>
1784</td><td valign="top" width="20%">total root dispersion to the primary reference clock
1785
1786<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>refid</code>
1787</td><td valign="top" width="20%">
1788reference ID or <a href="decode.html#kiss">kiss code</a>
1789
1790<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>reftime</code>
1791</td><td valign="top" width="20%">
1792reference time
1793
1794<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>reach</code>
1795</td><td valign="top" width="20%">
1796reach register (octal)
1797
1798<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>unreach</code>
1799</td><td valign="top" width="20%">
1800unreach counter
1801
1802<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>hmode</code>
1803</td><td valign="top" width="20%">
1804host mode (1-6)
1805
1806<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>pmode</code>
1807</td><td valign="top" width="20%">
1808peer mode (1-5)
1809
1810<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>hpoll</code>
1811</td><td valign="top" width="20%">
1812host poll exponent (log(2) s) (3-17)
1813<br></td></tr><tr align="left"><td valign="top" width="10%"><code>ppoll</code>
1814</td><td valign="top" width="20%">
1815peer poll exponent (log(2) s) (3-17)
1816
1817<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>headway</code>
1818</td><td valign="top" width="20%">
1819headway (see <a href="rate.html">Rate Management and the Kiss-o'-Death Packet</a>)
1820
1821<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>flash</code>
1822</td><td valign="top" width="20%">
1823<a href="decode.html#flash">flash status word</a>
1824
1825<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>offset</code>
1826</td><td valign="top" width="20%">
1827filter offset
1828
1829<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>delay</code>
1830</td><td valign="top" width="20%">
1831filter delay
1832
1833<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>dispersion</code>
1834</td><td valign="top" width="20%">
1835filter dispersion
1836
1837<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>jitter</code>
1838</td><td valign="top" width="20%">
1839filter jitter
1840
1841<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>ident</code>
1842</td><td valign="top" width="20%">
1843Autokey group name for this association
1844
1845<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>bias</code>
1846</td><td valign="top" width="20%">
1847unicast/broadcast bias
1848
1849<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>xleave</code>
1850</td><td valign="top" width="20%">
1851interleave delay (see <a href="xleave.html">NTP Interleaved Modes</a>)
1852
1853  <br></td></tr></table>
1854
1855  <p>The bias variable is calculated when the first broadcast packet is received
1856after the calibration volley.  It represents the offset of the broadcast
1857subgraph relative to the unicast subgraph.  The xleave variable appears
1858only the interleaved symmetric and interleaved modes.  It represents
1859the internal queuing, buffering and transmission delays for the preceding
1860packet.
1861
1862  <p>When the NTPv4 daemon is compiled with the OpenSSL software library,
1863additional peer variables are displayed, including the following:
1864
1865  <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1866
1867<p><br></th></tr><tr align="left"><td valign="top" width="10%"><code>flags</code>
1868</td><td valign="top" width="20%">
1869peer flags (see Autokey specification)
1870
1871<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>host</code>
1872</td><td valign="top" width="20%">
1873Autokey server name
1874
1875<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>flags</code>
1876</td><td valign="top" width="20%">
1877peer flags (see Autokey specification)
1878
1879<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>signature</code>
1880</td><td valign="top" width="20%">
1881OpenSSL digest/signature scheme
1882
1883<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>initsequence</code>
1884</td><td valign="top" width="20%">
1885initial key ID
1886
1887<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>initkey</code>
1888</td><td valign="top" width="20%">
1889initial key index
1890
1891<p><br></td></tr><tr align="left"><td valign="top" width="10%"><code>timestamp</code>
1892</td><td valign="top" width="20%">
1893Autokey signature timestamp
1894
1895  <br></td></tr></table>
1896
1897<div class="node">
1898<p><hr>
1899<a name="Clock-Variables"></a>Previous:&nbsp;<a rel="previous" accesskey="p" href="#Peer-Variables">Peer Variables</a>,
1900Up:&nbsp;<a rel="up" accesskey="u" href="#Top">Top</a>
1901<br>
1902</div>
1903
1904<!-- node-name,  next,  previous,  up -->
1905<h3 class="section">Clock Variables</h3>
1906
1907<p>The following clock variables appear in the <code>cv</code> billboard for each association with a reference clock.  Not all variables are displayed in some configurations.
1908
1909  <p><table summary=""><tr align="left"><th valign="top" width="10%">Variable </th><th valign="top" width="20%">Description
1910<br></th></tr><tr align="left"><td valign="top" width="10%"><code>associd</code>
1911</td><td valign="top" width="20%">association ID
1912<br></td></tr><tr align="left"><td valign="top" width="10%"><code>status</code>
1913</td><td valign="top" width="20%"><a href="decode.html#clock">clock status word</a>
1914<br></td></tr><tr align="left"><td valign="top" width="10%"><code>device</code>
1915</td><td valign="top" width="20%">device description
1916<br></td></tr><tr align="left"><td valign="top" width="10%"><code>timecode</code>
1917</td><td valign="top" width="20%">ASCII time code string (specific to device)
1918<br></td></tr><tr align="left"><td valign="top" width="10%"><code>poll</code>
1919</td><td valign="top" width="20%">poll messages sent
1920<br></td></tr><tr align="left"><td valign="top" width="10%"><code>noreply</code>
1921</td><td valign="top" width="20%">no reply
1922<br></td></tr><tr align="left"><td valign="top" width="10%"><code>badformat</code>
1923</td><td valign="top" width="20%">bad format
1924<br></td></tr><tr align="left"><td valign="top" width="10%"><code>baddata</code>
1925</td><td valign="top" width="20%">bad date or time
1926<br></td></tr><tr align="left"><td valign="top" width="10%"><code>fudgetime1</code>
1927</td><td valign="top" width="20%">fudge time 1
1928<br></td></tr><tr align="left"><td valign="top" width="10%"><code>fudgetime2</code>
1929</td><td valign="top" width="20%">fudge time 2
1930<br></td></tr><tr align="left"><td valign="top" width="10%"><code>stratum</code>
1931</td><td valign="top" width="20%">driver stratum
1932<br></td></tr><tr align="left"><td valign="top" width="10%"><code>refid</code>
1933</td><td valign="top" width="20%">driver reference ID
1934<br></td></tr><tr align="left"><td valign="top" width="10%"><code>flags</code>
1935</td><td valign="top" width="20%">driver flags
1936  <br></td></tr></table>
1937
1938</body></html>
1939
1940