1CHRONYC(1)                        User manual                       CHRONYC(1)
2
3
4

NAME

6       chronyc - command-line interface for chrony daemon
7

SYNOPSIS

9       chronyc [OPTION]... [COMMAND]...
10

DESCRIPTION

12       chronyc is a command-line interface program which can be used to
13       monitor chronyd’s performance and to change various operating
14       parameters whilst it is running.
15
16       If no commands are specified on the command line, chronyc will expect
17       input from the user. The prompt chronyc> will be displayed when it is
18       being run from a terminal. If chronyc’s input or output are redirected
19       from or to a file, the prompt is not shown.
20
21       There are two ways chronyc can access chronyd. One is the Internet
22       Protocol (IPv4 or IPv6) and the other is a Unix domain socket, which is
23       accessible locally by the root or chrony user. By default, chronyc
24       first tries to connect to the Unix domain socket. The compiled-in
25       default path is /var/run/chrony/chronyd.sock. If that fails (e.g.
26       because chronyc is running under a non-root user), it will try to
27       connect to 127.0.0.1 and then ::1.
28
29       Only the following monitoring commands, which do not affect the
30       behaviour of chronyd, are allowed from the network: activity, manual
31       list, rtcdata, smoothing, sources, sourcestats, tracking, waitsync. The
32       set of hosts from which chronyd will accept these commands can be
33       configured with the cmdallow directive in the chronyd’s configuration
34       file or the cmdallow command in chronyc. By default, the commands are
35       accepted only from localhost (127.0.0.1 or ::1).
36
37       All other commands are allowed only through the Unix domain socket.
38       When sent over the network, chronyd will respond with a ‘Not
39       authorised’ error, even if it is from localhost. In chrony versions
40       before 2.2 they were allowed from the network if they were
41       authenticated with a password, but that is no longer supported.
42
43       Having full access to chronyd via chronyc is more or less equivalent to
44       being able to modify the chronyd’s configuration file and restart it.
45

OPTIONS

47       -4
48           With this option hostnames will be resolved only to IPv4 addresses.
49
50       -6
51           With this option hostnames will be resolved only to IPv6 addresses.
52
53       -n
54           This option disables resolving of IP addresses to hostnames, e.g.
55           to avoid slow DNS lookups. Long addresses will not be truncated to
56           fit into the column.
57
58       -c
59           This option enables printing of reports in a comma-separated values
60           (CSV) format. IP addresses will not be resolved to hostnames, time
61           will be printed as number of seconds since the epoch and values in
62           seconds will not be converted to other units.
63
64       -d
65           This option enables printing of debugging messages if chronyc was
66           compiled with debugging support.
67
68       -m
69           Normally, all arguments on the command line are interpreted as one
70           command. With this option multiple commands can be specified. Each
71           argument will be interpreted as a whole command.
72
73       -h host
74           This option allows the user to specify which host (or
75           comma-separated list of addresses) running the chronyd program is
76           to be contacted. This allows for remote monitoring, without having
77           to connect over SSH to the other host first.
78
79           The default is to contact chronyd running on the same host where
80           chronyc is being run.
81
82       -p port
83           This option allows the user to specify the UDP port number which
84           the target chronyd is using for its monitoring connections. This
85           defaults to 323; there would rarely be a need to change this.
86
87       -f file
88           This option is ignored and is provided only for compatibility.
89
90       -a
91           This option is ignored and is provided only for compatibility.
92
93       -v
94           With this option chronyc displays its version number on the
95           terminal and exits.
96

COMMANDS

98       This section describes each of the commands available within the
99       chronyc program.
100
101   System clock
102       tracking
103           The tracking command displays parameters about the system’s clock
104           performance. An example of the output is shown below.
105
106               Reference ID    : CB00710F (foo.example.net)
107               Stratum         : 3
108               Ref time (UTC)  : Fri Jan 27 09:49:17 2017
109               System time     : 0.000006523 seconds slow of NTP time
110               Last offset     : -0.000006747 seconds
111               RMS offset      : 0.000035822 seconds
112               Frequency       : 3.225 ppm slow
113               Residual freq   : -0.000 ppm
114               Skew            : 0.129 ppm
115               Root delay      : 0.013639022 seconds
116               Root dispersion : 0.001100737 seconds
117               Update interval : 64.2 seconds
118               Leap status     : Normal
119
120           The fields are explained as follows:
121
122           Reference ID
123               This is the reference ID and name (or IP address) of the server
124               to which the computer is currently synchronised. For IPv4
125               addresses, the reference ID is equal to the address and for
126               IPv6 addresses it is the first 32 bits of the MD5 sum of the
127               address.
128
129               If the reference ID is 7F7F0101 and there is no name or IP
130               address, it means the computer is not synchronised to any
131               external source and that you have the local mode operating (via
132               the local command in chronyc, or the local directive in the
133               configuration file).
134
135               The reference ID is printed as a hexadecimal number. Note that
136               in older versions it used to be printed in quad-dotted notation
137               and could be confused with an IPv4 address.
138
139           Stratum
140               The stratum indicates how many hops away from a computer with
141               an attached reference clock we are. Such a computer is a
142               stratum-1 computer, so the computer in the example is two hops
143               away (i.e. foo.example.net is a stratum-2 and is synchronised
144               from a stratum-1).
145
146           Ref time
147               This is the time (UTC) at which the last measurement from the
148               reference source was processed.
149
150           System time
151               In normal operation, chronyd by default never steps the system
152               clock, because any jump in the time can have adverse
153               consequences for certain application programs. Instead, any
154               error in the system clock is corrected by slightly speeding up
155               or slowing down the system clock until the error has been
156               removed, and then returning to the system clock’s normal speed.
157               A consequence of this is that there will be a period when the
158               system clock (as read by other programs) will be different from
159               chronyd’s estimate of the current true time (which it reports
160               to NTP clients when it is operating in server mode). The value
161               reported on this line is the difference due to this effect.
162
163           Last offset
164               This is the estimated local offset on the last clock update.
165
166           RMS offset
167               This is a long-term average of the offset value.
168
169           Frequency
170               The ‘frequency’ is the rate by which the system’s clock would
171               be wrong if chronyd was not correcting it. It is expressed in
172               ppm (parts per million). For example, a value of 1 ppm would
173               mean that when the system’s clock thinks it has advanced 1
174               second, it has actually advanced by 1.000001 seconds relative
175               to true time.
176
177           Residual freq
178               This shows the ‘residual frequency’ for the currently selected
179               reference source. This reflects any difference between what the
180               measurements from the reference source indicate the frequency
181               should be and the frequency currently being used.
182
183               The reason this is not always zero is that a smoothing
184               procedure is applied to the frequency. Each time a measurement
185               from the reference source is obtained and a new residual
186               frequency computed, the estimated accuracy of this residual is
187               compared with the estimated accuracy (see ‘skew’ next) of the
188               existing frequency value. A weighted average is computed for
189               the new frequency, with weights depending on these accuracies.
190               If the measurements from the reference source follow a
191               consistent trend, the residual will be driven to zero over
192               time.
193
194           Skew
195               This is the estimated error bound on the frequency.
196
197           Root delay
198               This is the total of the network path delays to the stratum-1
199               computer from which the computer is ultimately synchronised.
200
201           Root dispersion
202               This is the total dispersion accumulated through all the
203               computers back to the stratum-1 computer from which the
204               computer is ultimately synchronised. Dispersion is due to
205               system clock resolution, statistical measurement variations,
206               etc.
207
208               An absolute bound on the computer’s clock accuracy (assuming
209               the stratum-1 computer is correct) is given by:
210
211                   clock_error <= |system_time_offset| + root_dispersion + (0.5 * root_delay)
212
213           Update interval
214               This is the interval between the last two clock updates.
215
216           Leap status
217               This is the leap status, which can be Normal, Insert second,
218               Delete second or Not synchronised.
219
220       makestep, makestep threshold limit
221           Normally chronyd will cause the system to gradually correct any
222           time offset, by slowing down or speeding up the clock as required.
223           In certain situations, the system clock might be so far adrift that
224           this slewing process would take a very long time to correct the
225           system clock.
226
227           The makestep command can be used in this situation. There are two
228           forms of the command. The first form has no parameters. It tells
229           chronyd to cancel any remaining correction that was being slewed
230           and jump the system clock by the equivalent amount, making it
231           correct immediately.
232
233           The second form configures the automatic stepping, similarly to the
234           makestep directive. It has two parameters, stepping threshold (in
235           seconds) and number of future clock updates for which the threshold
236           will be active. This can be used with the burst command to quickly
237           make a new measurement and correct the clock by stepping if needed,
238           without waiting for chronyd to complete the measurement and update
239           the clock.
240
241               makestep 0.1 1
242               burst 1/2
243
244           BE WARNED: Certain software will be seriously affected by such
245           jumps in the system time. (That is the reason why chronyd uses
246           slewing normally.)
247
248       maxupdateskew skew-in-ppm
249           This command has the same effect as the maxupdateskew directive in
250           the configuration file.
251
252       waitsync [max-tries [max-correction [max-skew [interval]]]]
253           The waitsync command waits for chronyd to synchronise.
254
255           Up to four optional arguments can be specified. The first is the
256           maximum number of tries before giving up and returning a non-zero
257           error code. When 0 is specified, or there are no arguments, the
258           number of tries will not be limited.
259
260           The second and third arguments are the maximum allowed remaining
261           correction of the system clock and the maximum allowed skew (in
262           ppm) as reported by the tracking command in the System time and
263           Skew fields. If not specified or zero, the value will not be
264           checked.
265
266           The fourth argument is the interval specified in seconds in which
267           the check is repeated. The interval is 10 seconds by default.
268
269           An example is:
270
271               waitsync 60 0.01
272
273           which will wait up to about 10 minutes (60 times 10 seconds) for
274           chronyd to synchronise to a source and the remaining correction to
275           be less than 10 milliseconds.
276
277   Time sources
278       sources [-v]
279           This command displays information about the current time sources
280           that chronyd is accessing.
281
282           The optional argument -v can be specified, meaning verbose. In this
283           case, extra caption lines are shown as a reminder of the meanings
284           of the columns.
285
286               210 Number of sources = 3
287               MS Name/IP address         Stratum Poll Reach LastRx Last sample
288               ===============================================================================
289               #* GPS0                          0   4   377    11   -479ns[ -621ns] +/-  134ns
290               ^? foo.example.net               2   6   377    23   -923us[ -924us] +/-   43ms
291               ^+ bar.example.net               1   6   377    21  -2629us[-2619us] +/-   86ms
292
293           The columns are as follows:
294
295           M
296               This indicates the mode of the source. ^ means a server, =
297               means a peer and # indicates a locally connected reference
298               clock.
299
300           S
301               This column indicates the state of the source.
302
303               ·   * indicates the source to which chronyd is currently
304                   synchronised.
305
306               ·   + indicates acceptable sources which are combined with the
307                   selected source.
308
309               ·   - indicates acceptable sources which are excluded by the
310                   combining algorithm.
311
312               ·   ? indicates sources to which connectivity has been lost or
313                   whose packets do not pass all tests. It is also shown at
314                   start-up, until at least 3 samples have been gathered from
315                   it.
316
317               ·   x indicates a clock which chronyd thinks is a falseticker
318                   (i.e. its time is inconsistent with a majority of other
319                   sources).
320
321               ·   ~ indicates a source whose time appears to have too much
322                   variability.
323
324           Name/IP address
325               This shows the name or the IP address of the source, or
326               reference ID for reference clocks.
327
328           Stratum
329               This shows the stratum of the source, as reported in its most
330               recently received sample. Stratum 1 indicates a computer with a
331               locally attached reference clock. A computer that is
332               synchronised to a stratum 1 computer is at stratum 2. A
333               computer that is synchronised to a stratum 2 computer is at
334               stratum 3, and so on.
335
336           Poll
337               This shows the rate at which the source is being polled, as a
338               base-2 logarithm of the interval in seconds. Thus, a value of 6
339               would indicate that a measurement is being made every 64
340               seconds. chronyd automatically varies the polling rate in
341               response to prevailing conditions.
342
343           Reach
344               This shows the source’s reachability register printed as an
345               octal number. The register has 8 bits and is updated on every
346               received or missed packet from the source. A value of 377
347               indicates that a valid reply was received for all from the last
348               eight transmissions.
349
350           LastRx
351               This column shows how long ago the last sample was received
352               from the source. This is normally in seconds. The letters m, h,
353               d or y indicate minutes, hours, days, or years.
354
355           Last sample
356               This column shows the offset between the local clock and the
357               source at the last measurement. The number in the square
358               brackets shows the actual measured offset. This can be suffixed
359               by ns (indicating nanoseconds), us (indicating microseconds),
360               ms (indicating milliseconds), or s (indicating seconds). The
361               number to the left of the square brackets shows the original
362               measurement, adjusted to allow for any slews applied to the
363               local clock since. The number following the +/- indicator shows
364               the margin of error in the measurement. Positive offsets
365               indicate that the local clock is ahead of the source.
366
367       sourcestats [-v]
368           The sourcestats command displays information about the drift rate
369           and offset estimation process for each of the sources currently
370           being examined by chronyd.
371
372           The optional argument -v can be specified, meaning verbose. In this
373           case, extra caption lines are shown as a reminder of the meanings
374           of the columns.
375
376           An example report is:
377
378               210 Number of sources = 1
379               Name/IP Address            NP  NR  Span  Frequency  Freq Skew  Offset  Std Dev
380               ===============================================================================
381               foo.example.net            11   5   46m     -0.001      0.045      1us    25us
382
383           The columns are as follows:
384
385           Name/IP Address
386               This is the name or IP address of the NTP server (or peer) or
387               reference ID of the reference clock to which the rest of the
388               line relates.
389
390           NP
391               This is the number of sample points currently being retained
392               for the server. The drift rate and current offset are estimated
393               by performing a linear regression through these points.
394
395           NR
396               This is the number of runs of residuals having the same sign
397               following the last regression. If this number starts to become
398               too small relative to the number of samples, it indicates that
399               a straight line is no longer a good fit to the data. If the
400               number of runs is too low, chronyd discards older samples and
401               re-runs the regression until the number of runs becomes
402               acceptable.
403
404           Span
405               This is the interval between the oldest and newest samples. If
406               no unit is shown the value is in seconds. In the example, the
407               interval is 46 minutes.
408
409           Frequency
410               This is the estimated residual frequency for the server, in
411               parts per million. In this case, the computer’s clock is
412               estimated to be running 1 part in 10^9 slow relative to the
413               server.
414
415           Freq Skew
416               This is the estimated error bounds on Freq (again in parts per
417               million).
418
419           Offset
420               This is the estimated offset of the source.
421
422           Std Dev
423               This is the estimated sample standard deviation.
424
425       reselect
426           To avoid excessive switching between sources, chronyd can stay
427           synchronised to a source even when it is not currently the best one
428           among the available sources.
429
430           The reselect command can be used to force chronyd to reselect the
431           best synchronisation source.
432
433       reselectdist distance
434           The reselectdist command sets the reselection distance. It is
435           equivalent to the reselectdist directive in the configuration file.
436
437   NTP sources
438       activity
439           This command reports the number of servers and peers that are
440           online and offline. If the auto_offline option is used in
441           specifying some of the servers or peers, the activity command can
442           be useful for detecting when all of them have entered the offline
443           state after the network link has been disconnected.
444
445           The report shows the number of servers and peers in 5 states:
446
447           online
448               the server or peer is currently online (i.e. assumed by chronyd
449               to be reachable)
450
451           offline
452               the server or peer is currently offline (i.e. assumed by
453               chronyd to be unreachable, and no measurements from it will be
454               attempted.)
455
456           burst_online
457               a burst command has been initiated for the server or peer and
458               is being performed; after the burst is complete, the server or
459               peer will be returned to the online state.
460
461           burst_offline
462               a burst command has been initiated for the server or peer and
463               is being performed; after the burst is complete, the server or
464               peer will be returned to the offline state.
465
466           unresolved
467               the name of the server or peer was not resolved to an address
468               yet; this source is not visible in the sources and sourcestats
469               reports.
470
471       ntpdata [address]
472           The ntpdata command displays the last valid measurement and other
473           NTP-specific information about the specified NTP source, or all NTP
474           sources if no address was specified. An example of the output is
475           shown below.
476
477               Remote address  : 203.0.113.15 (CB00710F)
478               Remote port     : 123
479               Local address   : 203.0.113.74 (CB00714A)
480               Leap status     : Normal
481               Version         : 4
482               Mode            : Server
483               Stratum         : 1
484               Poll interval   : 10 (1024 seconds)
485               Precision       : -24 (0.000000060 seconds)
486               Root delay      : 0.000015 seconds
487               Root dispersion : 0.000015 seconds
488               Reference ID    : 47505300 (GPS)
489               Reference time  : Fri Nov 25 15:22:12 2016
490               Offset          : -0.000060878 seconds
491               Peer delay      : 0.000175634 seconds
492               Peer dispersion : 0.000000681 seconds
493               Response time   : 0.000053050 seconds
494               Jitter asymmetry: +0.00
495               NTP tests       : 111 111 1111
496               Interleaved     : No
497               Authenticated   : No
498               TX timestamping : Kernel
499               RX timestamping : Kernel
500               Total TX        : 24
501               Total RX        : 24
502               Total valid RX  : 24
503
504           The fields are explained as follows:
505
506           Remote address
507               The IP address of the NTP server or peer, and the corresponding
508               reference ID.
509
510           Remote port
511               The UDP port number to which the request was sent. The standard
512               NTP port is 123.
513
514           Local address
515               The local IP address which received the response, and the
516               corresponding reference ID.
517
518           Leap status, Version, Mode, Stratum, Poll interval, Precision, Root
519           delay, Root dispersion, Reference ID, Reference time
520               The NTP values from the last valid response.
521
522           Offset, Peer delay, Peer dispersion
523               The measured values.
524
525           Response time
526               The time the server or peer spent in processing of the request
527               and waiting before sending the response.
528
529           Jitter asymmetry
530               The estimated asymmetry of network jitter on the path to the
531               source. The asymmetry can be between -0.5 and 0.5. A negative
532               value means the delay of packets sent to the source is more
533               variable than the delay of packets sent from the source back.
534
535           NTP tests
536               Results of RFC 5905 tests 1 through 3, 5 through 7, and tests
537               for maximum delay, delay ratio, delay dev ratio, and
538               synchronisation loop.
539
540           Interleaved
541               This shows if the response was in the interleaved mode.
542
543           Authenticated
544               This shows if the response was authenticated.
545
546           TX timestamping
547               The source of the local transmit timestamp. Valid values are
548               Daemon, Kernel, and Hardware.
549
550           RX timestamping
551               The source of the local receive timestamp.
552
553           Total TX
554               The number of packets sent to the source.
555
556           Total RX
557               The number of all packets received from the source.
558
559           Total valid RX
560               The number of valid packets received from the source.
561
562       add peer address [option]...
563           The add peer command allows a new NTP peer to be added whilst
564           chronyd is running.
565
566           Following the words add peer, the syntax of the following
567           parameters and options is similar to that for the peer directive in
568           the configuration file. The following peer options can be set in
569           the command: port, minpoll, maxpoll, presend, maxdelayratio,
570           maxdelay, key.
571
572           An example of using this command is shown below.
573
574               add peer foo.example.net minpoll 6 maxpoll 10 key 25
575
576       add server address [option]...
577           The add server command allows a new NTP server to be added whilst
578           chronyd is running.
579
580           Following the words add server, the syntax of the following
581           parameters and options is similar to that for the server directive
582           in the configuration file. The following server options can be set
583           in the command: port, minpoll, maxpoll, presend, maxdelayratio,
584           maxdelay, key.
585
586           An example of using this command is shown below:
587
588               add server foo.example.net minpoll 6 maxpoll 10 key 25
589
590       delete address
591           The delete command allows an NTP server or peer to be removed from
592           the current set of sources.
593
594       burst good/max [mask/masked-address], burst good/max
595       [masked-address/masked-bits], burst good/max [address]
596           The burst command tells chronyd to make a set of measurements to
597           each of its NTP sources over a short duration (rather than the
598           usual periodic measurements that it makes). After such a burst,
599           chronyd will revert to the previous state for each source. This
600           might be either online, if the source was being periodically
601           measured in the normal way, or offline, if the source had been
602           indicated as being offline. (A source can be switched between the
603           online and offline states with the online and offline commands.)
604
605           The mask and masked-address arguments are optional, in which case
606           chronyd will initiate a burst for all of its currently defined
607           sources.
608
609           The arguments have the following meaning and format:
610
611           good
612               This defines the number of good measurements that chronyd will
613               want to obtain from each source. A measurement is good if it
614               passes certain tests, for example, the round trip time to the
615               source must be acceptable. (This allows chronyd to reject
616               measurements that are likely to be bogus.)
617
618           max
619               This defines the maximum number of measurements that chronyd
620               will attempt to make, even if the required number of good
621               measurements has not been obtained.
622
623           mask
624               This is an IP address with which the IP address of each of
625               chronyd’s sources is to be masked.
626
627           masked-address
628               This is an IP address. If the masked IP address of a source
629               matches this value then the burst command is applied to that
630               source.
631
632           masked-bits
633               This can be used with masked-address for CIDR notation, which
634               is a shorter alternative to the form with mask.
635
636           address
637               This is an IP address or a hostname. The burst command is
638               applied only to that source.
639
640
641
642           If no mask or masked-address arguments are provided, every source
643           will be matched.
644
645           An example of the two-argument form of the command is:
646
647               burst 2/10
648
649           This will cause chronyd to attempt to get two good measurements
650           from each source, stopping after two have been obtained, but in no
651           event will it try more than ten probes to the source.
652
653           Examples of the four-argument form of the command are:
654
655               burst 2/10 255.255.0.0/1.2.0.0
656               burst 2/10 2001:db8:789a::/48
657
658           In the first case, the two out of ten sampling will only be applied
659           to sources whose IPv4 addresses are of the form 1.2.x.y, where x
660           and y are arbitrary. In the second case, the sampling will be
661           applied to sources whose IPv6 addresses have first 48 bits equal to
662           2001:db8:789a.
663
664           Example of the three-argument form of the command is:
665
666               burst 2/10 foo.example.net
667
668       maxdelay address delay
669           This allows the maxdelay option for one of the sources to be
670           modified, in the same way as specifying the maxdelay option for the
671           server directive in the configuration file.
672
673       maxdelaydevratio address ratio
674           This allows the maxdelaydevratio option for one of the sources to
675           be modified, in the same way as specifying the maxdelaydevratio
676           option for the server directive in the configuration file.
677
678       maxdelayratio address ratio
679           This allows the maxdelayratio option for one of the sources to be
680           modified, in the same way as specifying the maxdelayratio option
681           for the server directive in the configuration file.
682
683       maxpoll address maxpoll
684           The maxpoll command is used to modify the maximum polling interval
685           for one of the current set of sources. It is equivalent to the
686           maxpoll option in the server directive in the configuration file.
687
688           Note that the new maximum polling interval only takes effect after
689           the next measurement has been made.
690
691       minpoll address minpoll
692           The minpoll command is used to modify the minimum polling interval
693           for one of the current set of sources. It is equivalent to the
694           minpoll option in the server directive in the configuration file.
695
696           Note that the new minimum polling interval only takes effect after
697           the next measurement has been made.
698
699       minstratum address minstratum
700           The minstratum command is used to modify the minimum stratum for
701           one of the current set of sources. It is equivalent to the
702           minstratum option in the server directive in the configuration
703           file.
704
705       offline [address], offline [masked-address/masked-bits], offline
706       [mask/masked-address]
707           The offline command is used to warn chronyd that the network
708           connection to a particular host or hosts is about to be lost, e.g.
709           on computers with intermittent connection to their time sources.
710
711           Another case where offline could be used is where a computer serves
712           time to a local group of computers, and has a permanent connection
713           to true time servers outside the organisation. However, the
714           external connection is heavily loaded at certain times of the day
715           and the measurements obtained are less reliable at those times. In
716           this case, it is probably most useful to determine the gain or loss
717           rate during the quiet periods and let the whole network coast
718           through the loaded periods. The offline and online commands can be
719           used to achieve this.
720
721           There are four forms of the offline command. The first form is a
722           wildcard, meaning all sources. The second form allows an IP address
723           mask and a masked address to be specified. The third form uses CIDR
724           notation. The fourth form uses an IP address or a hostname. These
725           forms are illustrated below.
726
727               offline
728               offline 255.255.255.0/1.2.3.0
729               offline 2001:db8:789a::/48
730               offline foo.example.net
731
732           The second form means that the offline command is to be applied to
733           any source whose IPv4 address is in the 1.2.3 subnet. (The host’s
734           address is logically and-ed with the mask, and if the result
735           matches the masked-address the host is processed.) The third form
736           means that the command is to be applied to all sources whose IPv6
737           addresses have their first 48 bits equal to 2001:db8:789a. The
738           fourth form means that the command is to be applied only to that
739           one source.
740
741           The wildcard form of the address is equivalent to:
742
743               offline 0.0.0.0/0.0.0.0
744               offline ::/0
745
746       online [address], online [masked-address/masked-bits], online
747       [mask/masked-address]
748           The online command is opposite in function to the offline command.
749           It is used to advise chronyd that network connectivity to a
750           particular source or sources has been restored.
751
752           The syntax is identical to that of the offline command.
753
754       polltarget address polltarget
755           The polltarget command is used to modify the poll target for one of
756           the current set of sources. It is equivalent to the polltarget
757           option in the server directive in the configuration file.
758
759       refresh
760           The refresh command can be used to force chronyd to resolve the
761           names of configured sources to IP addresses again, e.g. after
762           suspending and resuming the machine in a different network.
763
764           Sources that stop responding will be replaced with newly resolved
765           addresses automatically after 8 polling intervals, but this command
766           can still be useful to replace them immediately and not wait until
767           they are marked as unreachable.
768
769   Manual time input
770       manual on, manual off, manual delete index, manual list, manual reset
771           The manual command enables and disables use of the settime command,
772           and is used to modify the behaviour of the manual clock driver.
773
774           The on form of the command enables use of the settime command.
775
776           The off form of the command disables use of the settime command.
777
778           The list form of the command lists all the samples currently stored
779           in chronyd. The output is illustrated below.
780
781               210 n_samples = 1
782               #    Date  Time(UTC)    Slewed   Original   Residual
783               ====================================================
784                0 27Jan99 22:09:20       0.00       0.97       0.00
785
786           The columns are as as follows:
787
788            1. The sample index (used for the manual delete command).
789
790            2. The date and time of the sample.
791
792            3. The system clock error when the timestamp was entered, adjusted
793               to allow for changes made to the system clock since.
794
795            4. The system clock error when the timestamp was entered, as it
796               originally was (without allowing for changes to the system
797               clock since).
798
799            5. The regression residual at this point, in seconds. This allows
800               ‘outliers’ to be easily spotted, so that they can be deleted
801               using the manual delete command.
802
803
804
805           The delete form of the command deletes a single sample. The
806           parameter is the index of the sample, as shown in the first column
807           of the output from manual list. Following deletion of the data
808           point, the current error and drift rate are re-estimated from the
809           remaining data points and the system clock trimmed if necessary.
810           This option is intended to allow ‘outliers’ to be discarded, i.e.
811           samples where the administrator realises they have entered a very
812           poor timestamp.
813
814           The reset form of the command deletes all samples at once. The
815           system clock is left running as it was before the command was
816           entered.
817
818       settime time
819           The settime command allows the current time to be entered manually,
820           if this option has been configured into chronyd. (It can be
821           configured either with the manual directive in the configuration
822           file, or with the manual command of chronyc.)
823
824           It should be noted that the computer’s sense of time will only be
825           as accurate as the reference you use for providing this input (e.g.
826           your watch), as well as how well you can time the press of the
827           return key.
828
829           Providing your computer’s time zone is set up properly, you will be
830           able to enter a local time (rather than UTC).
831
832           The response to a successful settime command indicates the amount
833           that the computer’s clock was wrong. It should be apparent from
834           this if you have entered the time wrongly, e.g. with the wrong time
835           zone.
836
837           The rate of drift of the system clock is estimated by a regression
838           process using the entered measurement and all previous measurements
839           entered during the present run of chronyd. However, the entered
840           measurement is used for adjusting the current clock offset (rather
841           than the estimated intercept from the regression, which is
842           ignored). Contrast what happens with the manual delete command,
843           where the intercept is used to set the current offset (since there
844           is no measurement that has just been entered in that case).
845
846           The time is parsed by the public domain getdate algorithm.
847           Consequently, you can only specify time to the nearest second.
848
849           Examples of inputs that are valid are shown below:
850
851               settime 16:30
852               settime 16:30:05
853               settime Nov 21, 2015 16:30:05
854
855           For a full description of getdate, see the getdate documentation
856           (bundled, for example, with the source for GNU tar).
857
858   NTP access
859       accheck address
860           This command allows you to check whether client NTP access is
861           allowed from a particular host.
862
863           Examples of use, showing a named host and a numeric IP address, are
864           as follows:
865
866               accheck foo.example.net
867               accheck 1.2.3.4
868               accheck 2001:db8::1
869
870           This command can be used to examine the effect of a series of
871           allow, allow all, deny, and deny all commands specified either via
872           chronyc, or in chronyd’s configuration file.
873
874       clients
875           This command shows a list of clients that have accessed the server,
876           through either the NTP or command ports. It does not include
877           accesses over the Unix domain command socket. There are no
878           arguments.
879
880           An example of the output is:
881
882               Hostname                      NTP   Drop Int IntL Last     Cmd   Drop Int  Last
883               ===============================================================================
884               localhost                       2      0   2   -   133      15      0  -1     7
885               foo.example.net                12      0   6   -    23       0      0   -     -
886
887           Each row shows the data for a single host. Only hosts that have
888           passed the host access checks (set with the allow, deny, cmdallow
889           and cmddeny commands or configuration file directives) are logged.
890           The intervals are displayed as a power of 2 in seconds.
891
892           The columns are as follows:
893
894            1. The hostname of the client.
895
896            2. The number of NTP packets received from the client.
897
898            3. The number of NTP packets dropped to limit the response rate.
899
900            4. The average interval between NTP packets.
901
902            5. The average interval between NTP packets after limiting the
903               response rate.
904
905            6. Time since the last NTP packet was received
906
907            7. The number of command packets received from the client.
908
909            8. The number of command packets dropped to limit the response
910               rate.
911
912            9. The average interval between command packets.
913
914            10. Time since the last command packet was received.
915
916       serverstats
917           The serverstats command displays how many valid NTP and command
918           requests chronyd as a server received from clients, how many of
919           them were dropped to limit the response rate as configured by the
920           ratelimit and cmdratelimit directives, and how many client log
921           records were dropped due to the memory limit configured by the
922           clientloglimit directive. An example of the output is shown below.
923
924               NTP packets received       : 1598
925               NTP packets dropped        : 8
926               Command packets received   : 19
927               Command packets dropped    : 0
928               Client log records dropped : 0
929
930       allow [all] [subnet]
931           The effect of the allow command is identical to the allow directive
932           in the configuration file.
933
934           The syntax is illustrated in the following examples:
935
936               allow foo.example.net
937               allow all 1.2
938               allow 3.4.5
939               allow 6.7.8/22
940               allow 6.7.8.9/22
941               allow 2001:db8:789a::/48
942               allow 0/0
943               allow ::/0
944               allow
945               allow all
946
947       deny [all] [subnet]
948           The effect of the allow command is identical to the deny directive
949           in the configuration file.
950
951           The syntax is illustrated in the following examples:
952
953               deny foo.example.net
954               deny all 1.2
955               deny 3.4.5
956               deny 6.7.8/22
957               deny 6.7.8.9/22
958               deny 2001:db8:789a::/48
959               deny 0/0
960               deny ::/0
961               deny
962               deny all
963
964       local [option]..., local off
965           The local command allows chronyd to be told that it is to appear as
966           a reference source, even if it is not itself properly synchronised
967           to an external source. (This can be used on isolated networks, to
968           allow one computer to be a master time server with the other
969           computers slaving to it.)
970
971           The first form enables the local reference mode on the host. The
972           syntax is identical to the local directive in the configuration
973           file.
974
975           The second form disables the local reference mode.
976
977       smoothing
978           The smoothing command displays the current state of the NTP server
979           time smoothing, which can be enabled with the smoothtime directive.
980           An example of the output is shown below.
981
982               Active         : Yes
983               Offset         : +1.000268817 seconds
984               Frequency      : -0.142859 ppm
985               Wander         : -0.010000 ppm per second
986               Last update    : 17.8 seconds ago
987               Remaining time : 19988.4 seconds
988
989           The fields are explained as follows:
990
991           Active
992               This shows if the server time smoothing is currently active.
993               Possible values are Yes and No. If the leaponly option is
994               included in the smoothtime directive, (leap second only) will
995               be shown on the line.
996
997           Offset
998               This is the current offset applied to the time sent to NTP
999               clients. Positive value means the clients are getting time
1000               that’s ahead of true time.
1001
1002           Frequency
1003               The current frequency offset of the served time. Negative value
1004               means the time observed by clients is running slower than true
1005               time.
1006
1007           Wander
1008               The current frequency wander of the served time. Negative value
1009               means the time observed by clients is slowing down.
1010
1011           Last update
1012               This field shows how long ago the time smoothing process was
1013               updated, e.g. chronyd accumulated a new measurement.
1014
1015           Remaining time
1016               The time it would take for the smoothing process to get to zero
1017               offset and frequency if there were no more updates.
1018
1019       smoothtime activate, smoothtime reset
1020           The smoothtime command can be used to activate or reset the server
1021           time smoothing process if it is configured with the smoothtime
1022           directive.
1023
1024   Monitoring access
1025       cmdaccheck address
1026           This command is similar to the accheck command, except that it is
1027           used to check whether monitoring access is permitted from a named
1028           host.
1029
1030           Examples of use are as follows:
1031
1032               cmdaccheck foo.example.net
1033               cmdaccheck 1.2.3.4
1034               cmdaccheck 2001:db8::1
1035
1036       cmdallow [all] [subnet]
1037           This is similar to the allow command, except that it is used to
1038           allow particular hosts or subnets to use chronyc to monitor with
1039           chronyd on the current host.
1040
1041       cmddeny [all] [subnet]
1042           This is similar to the deny command, except that it is used to
1043           allow particular hosts or subnets to use chronyc to monitor chronyd
1044           on the current host.
1045
1046   Real-time clock (RTC)
1047       rtcdata
1048           The rtcdata command displays the current RTC parameters.
1049
1050           An example output is shown below.
1051
1052               RTC ref time (GMT) : Sat May 30 07:25:56 2015
1053               Number of samples  : 10
1054               Number of runs     : 5
1055               Sample span period :  549
1056               RTC is fast by     :    -1.632736 seconds
1057               RTC gains time at  :  -107.623 ppm
1058
1059           The fields have the following meaning:
1060
1061           RTC ref time (GMT)
1062               This is the RTC reading the last time its error was measured.
1063
1064           Number of samples
1065               This is the number of previous measurements being used to
1066               determine the RTC gain or loss rate.
1067
1068           Number of runs
1069               This is the number of runs of residuals of the same sign
1070               following the regression fit for (RTC error) versus (RTC time).
1071               A value which is small indicates that the measurements are not
1072               well approximated by a linear model, and that the algorithm
1073               will tend to delete the older measurements to improve the fit.
1074
1075           Sample span period
1076               This is the period that the measurements span (from the oldest
1077               to the newest). Without a unit the value is in seconds;
1078               suffixes m for minutes, h for hours, d for days or y for years
1079               can be used.
1080
1081           RTC is fast by
1082               This is the estimate of how many seconds fast the RTC when it
1083               thought the time was at the reference time (above). If this
1084               value is large, you might (or might not) want to use the
1085               trimrtc command to bring the RTC into line with the system
1086               clock. (Note, a large error will not affect chronyd’s
1087               operation, unless it becomes so big as to start causing
1088               rounding errors.)
1089
1090           RTC gains time at
1091               This is the amount of time gained (positive) or lost (negative)
1092               by the real time clock for each second that it ticks. It is
1093               measured in parts per million. So if the value shown was +1,
1094               suppose the RTC was exactly right when it crosses a particular
1095               second boundary. Then it would be 1 microsecond fast when it
1096               crosses its next second boundary.
1097
1098       trimrtc
1099           The trimrtc command is used to correct the system’s real-time clock
1100           (RTC) to the main system clock. It has no effect if the error
1101           between the two clocks is currently estimated at less than a
1102           second.
1103
1104           The command takes no arguments. It performs the following steps (if
1105           the RTC is more than 1 second away from the system clock):
1106
1107            1. Remember the currently estimated gain or loss rate of the RTC
1108               and flush the previous measurements.
1109
1110            2. Step the real-time clock to bring it within a second of the
1111               system clock.
1112
1113            3. Make several measurements to accurately determine the new
1114               offset between the RTC and the system clock (i.e. the remaining
1115               fraction of a second error).
1116
1117            4. Save the RTC parameters to the RTC file (specified with the
1118               rtcfile directive in the configuration file).
1119
1120
1121
1122           The last step is done as a precaution against the computer
1123           suffering a power failure before either the daemon exits or the
1124           writertc command is issued.
1125
1126           chronyd will still work perfectly well both whilst operating and
1127           across machine reboots even if the trimrtc command is never used
1128           (and the RTC is allowed to drift away from true time). The trimrtc
1129           command is provided as a method by which it can be corrected, in a
1130           manner compatible with chronyd using it to maintain accurate time
1131           across machine reboots.
1132
1133           The trimrtc command can be executed automatically by chronyd with
1134           the rtcautotrim directive in the configuration file.
1135
1136       writertc
1137           The writertc command writes the currently estimated error and gain
1138           or loss rate parameters for the RTC to the RTC file (specified with
1139           the rtcfile directive). This information is also written
1140           automatically when chronyd is killed (by the SIGHUP, SIGINT,
1141           SIGQUIT or SIGTERM signals) or when the trimrtc command is issued.
1142
1143   Other daemon commands
1144       cyclelogs
1145           The cyclelogs command causes all of chronyd’s open log files to be
1146           closed and re-opened. This allows them to be renamed so that they
1147           can be periodically purged. An example of how to do this is shown
1148           below.
1149
1150               # mv /var/log/chrony/measurements.log /var/log/chrony/measurements1.log
1151               # chronyc cyclelogs
1152               # ls -l /var/log/chrony
1153               -rw-r--r--   1 root     root            0 Jun  8 18:17 measurements.log
1154               -rw-r--r--   1 root     root        12345 Jun  8 18:17 measurements1.log
1155               # rm -f measurements1.log
1156
1157       dump
1158           The dump command causes chronyd to write its current history of
1159           measurements for each of its sources to dump files in the directory
1160           specified in the configuration file by the dumpdir directive. Note
1161           that chronyd does this automatically when it exits. This command is
1162           mainly useful for inspection of the history whilst chronyd is
1163           running.
1164
1165       rekey
1166           The rekey command causes chronyd to re-read the key file specified
1167           in the configuration file by the keyfile directive.
1168
1169       shutdown
1170           The shutdown command causes chronyd to exit. This is equivalent to
1171           sending the process the SIGTERM signal.
1172
1173   Client commands
1174       dns option
1175           The dns command configures how hostnames and IP addresses are
1176           resolved in chronyc. IP addresses can be resolved to hostnames when
1177           printing results of sources, sourcestats, tracking and clients
1178           commands. Hostnames are resolved in commands that take an address
1179           as argument.
1180
1181           There are five options:
1182
1183           dns -n
1184               Disables resolving IP addresses to hostnames. Raw IP addresses
1185               will be displayed.
1186
1187           dns +n
1188               Enables resolving IP addresses to hostnames. This is the
1189               default unless chronyc was started with -n option.
1190
1191           dns -4
1192               Resolves hostnames only to IPv4 addresses.
1193
1194           dns -6
1195               Resolves hostnames only to IPv6 addresses.
1196
1197           dns -46
1198               Resolves hostnames to both address families. This is the
1199               default behaviour unless chronyc was started with the -4 or -6
1200               option.
1201
1202       timeout timeout
1203           The timeout command sets the initial timeout for chronyc requests
1204           in milliseconds. If no response is received from chronyd, the
1205           timeout is doubled and the request is resent. The maximum number of
1206           retries is configured with the retries command.
1207
1208           By default, the timeout is 1000 milliseconds.
1209
1210       retries retries
1211           The retries command sets the maximum number of retries for chronyc
1212           requests before giving up. The response timeout is controlled by
1213           the timeout command.
1214
1215           The default is 2.
1216
1217       keygen [id [type [bits]]]
1218           The keygen command generates a key that can be added to the key
1219           file (specified with the keyfile directive) to allow NTP
1220           authentication between server and client, or peers. The key is
1221           generated from the /dev/urandom device and it is printed to
1222           standard output.
1223
1224           The command has three optional arguments. The first argument is the
1225           key number (by default 1), which will be specified with the key
1226           option of the server or peer directives in the configuration file.
1227           The second argument is the hash function (by default SHA1 or MD5 if
1228           SHA1 is not available) and the third argument is the number of bits
1229           the key should have, between 80 and 4096 bits (by default 160
1230           bits).
1231
1232           An example is:
1233
1234               keygen 73 SHA1 256
1235
1236           which generates a 256-bit SHA1 key with number 73. The printed line
1237           should then be securely transferred and added to the key files on
1238           both server and client, or peers.
1239
1240       exit, quit
1241           The exit and quit commands exit from chronyc and return the user to
1242           the shell.
1243
1244       help
1245           The help command displays a summary of the commands and their
1246           arguments.
1247

SEE ALSO

1249       chrony.conf(5), chronyd(8)
1250

BUGS

1252       For instructions on how to report bugs, please visit <https://
1253       chrony.tuxfamily.org/>.
1254

AUTHORS

1256       chrony was written by Richard Curnow, Miroslav Lichvar, and others.
1257
1258
1259
1260chrony 3.3                        2018-04-04                        CHRONYC(1)
Impressum