The Clock Mini-HOWTO

Ron Bean, [email protected]

v, Dicembre 1996


Come regolare e mantenere sincronizzato l'orologio del tuo computer.

1. Introduzione

I chip RTC (NdT: Real-time-clock, orologio in tempo reale) usati sulle piastre madri dei PC (ed anche delle workstation più costose) sono notoriamente imprecisi. Linux fornisce un mezzo semplice per rimediare a questo via software, rendendo l'orologio potenzialmente *molto* preciso anche senza bisogno di sincronizzarlo continuamente a una fonte esterna. Ma la maggior parte delle persone non sembrano saperlo, per molte ragioni:

  1. Non è menzionato nella maggior parte dei documenti su come impostare Linux, e sarebbe difficile (sebbene non impossibile in teoria, se hai un modem) regolare automaticamente tali impostazioni all'installazione.
  2. Se consulti ``man clock'' otterrai clock(3), che non è ciò che ti serve (prova ``man 8 clock'').
  3. La maggior parte della gente non sembra essere interessata a che ora sia.
  4. Quei pochi cui interessa spesso usano il pacchetto xntpd da louie.udel.edu per sincronizzarsi ad una fonte esterna, come un network time server o un orologio radio.

Questo mini-HOWTO descrive l'approccio low-tech. Se sei maggiormente interessato a questi argomenti, ti raccomando caldamente di spendere un po' di tempo su http://www.eecis.udel.edu/~ntp/, che comprende molte cose interessanti, incluse informazioni complete su xntpd e collegamenti a NIST and USNO (aggiungerò un paio di commenti su xntpd alla fine).

Note

Se hai più di un sistema operativo sulla tua macchina, dovresti permettere ad uno solo di modificare l'orario dell'orologio CMOS, così che non si confondano l'un l'altro. Se usi regolarmente sia Linux che Windows sullo stesso computer, potresti provare uno dei programmi shareware di gestione dell'orologio interno che sono disponibili per windows (segui i collegamenti dall'URL qui sopra).

2. Usare il programma ``clock''

Tutto ciò che ti serve sapere è nella pagina del manuale clock(8), ma questo mini-HOWTO ti guiderà lungo la procedura.

Note

Devi avere i privilegi di root per lanciare ``clock'', o qualsiasi altro programma che intervenga sull'orario di sistema o sull'orologio CMOS.

2.1 Verificare la correttezza dell'installazione

Cerca nei tuoi file di avvio del sistema un comando tipo ``clock -a'' o ``clock -ua''. A seconda di quale distribuzione stai usando, potrebbe essere in /etc/rc.local, o /etc/rc.d/rc.sysinit, o qualche luogo simile.

Se dice ``clock -s'' o ``clock -us'', cambia la ``s'' in una ``a'', e poi verifica se hai il file /etc/adjtime, che contiene una singola linea che sembra qualcosa del genere:

0.000000 842214901 0.000000

Questi numeri sono il fattore di correzione (in secondi al giorno), il momento in cui l'orologio è stato corretto per l'ultima volta (in secondi dal 1� Gennaio 1970) e il secondo parziale che è stato arrotondato quella volta. Se non hai quel file, fai un login come root e crealo, con una singola linea che appaia così (tutti zero):

0.0 0 0.0

Poi lancia ``clock -a'' o ``clock -ua'' manualmente dalla shell per aggiornare il secondo numero (usa ``u'' se il tuo orologio è regolato sul tempo universale invece che sul locale).

2.2 Misurare la deriva dell'orologio

Per prima cosa, ti serve sapere che ora è :-). Il tuo tempo locale può essere accurato o no. Il mio metodo preferito è chiamare il servizio telefonico allo (303)499-7111 (NdT: per l'Italia è il 161 e costa due scatti). Se hai accesso a un network time server, puoi usare il programma ntpdate dal pacchetto xntpd (usa l'opzione -b per prevenire che il kernel faccia confusione nell'orologio CMOS). Altrimenti usa ``date -s hh:mm:ss'' per regolare manualmente l'orario del kernel, e poi ``clock -w'' per sincronizzare da esso l'orologio CMOS. Dovrai ricordarti quando hai regolato l'orologio per l'ultima volta, perciò annotati l'informazione da qualche parte. Se hai usato ntpdate, dai ``date +%s'' e annotati il numero dei secondi dal 1� Gennaio 1970

Poi torna dopo un po' di tempo e controlla quanto ha deviato l'orologio. Se l'avevi regolato a mano, raccomando di aspettare almeno due settimane, e di limitarti a calcolare la deriva alla prima cifra decimale di secondo al giorno (alcuni pretendono maggiore accuratezza qui, ma io sono abbastanza conservatore). Se hai usato ntpdate non dovrai aspettare così tanto, ma in ogni caso potrai regolare con maggiore precisione più tardi.

Puoi fare eseguire a cron il comando ``clock -a'' a intervalli regolari per tenere l'orologio di sistema sincronizzato con quello CMOS. Questo comando sarà anche eseguito dal tuo file d'avvio ogni volta che fai il boot, quindi se lo fai spesso (come molti di noi), questo dovrebbe essere sufficiente.

Nota che alcuni programmi potrebbero lamentarsi se l'orario salta di più di un secondo, o se viene spostato all'indietro. Se hai di questi problemi, puoi usare xntpd o ntpdate per correggere l'orario con maggiore gradualità.

2.3 Un esempio

Regolare l'orario

Fai il login come root. Componi il 161, e ascolta la comunicazione. Poi scrivi:

date -s hh:mm:ss
ma non premere Invio finchè non scatta il minuto (puoi usare ``ntpdate'' qui, al posto di ``date'', e risparmiarti la telefonata). Questo regola il ``kernel time'' (orario del kernel). Poi scrivi:
clock -w
Questo regola l'orologio CMOS in modo che si sincronizzi all'orario del kernel. Poi scrivi:
date +%j
(o ``date +%s'' se hai usato ``ntpdate'' al posto di ``date'', qui sopra) e annotati il dato fornito, per la prossima volta.

Reimpostare l'orario e controllare la deriva

Ritrova la data che ti eri annotato l'ultima volta. Fai il login come root, e poi scrivi:

clock -a
Questo regola l'orario del kernel per sincronizzarlo a quello CMOS. Componi il 161 e ascolta l'annuncio; poi scrivi:
date
e premi Invio quando scatta il minuto, ma mentre aspetti scriviti l'orario annunciato, e non riappendere ancora. Questo ti dice che ora la macchina pensava fosse, quando avrebbe dovuto scattare precisamente il minuto. Adesso scrivi:
date hh:mm:00
usando il minuto *dopo* quello che è appena stato annunciato, e premi Invio quando senti di nuovo che il minuto scatta (adesso puoi riappendere). Per hh usa l'ora locale. Questo regola il ``kernel time''. Poi digita:
clock -w
che scrive il nuovo (e corretto) orario nell'orologio CMOS. Adesso immetti:
date +%j
(o ``date +%s'' se hai usato questo, più sopra)

Adesso hai tre numeri (due date e un orario) che ti permetteranno di calcolare la deriva.

Calcolare il fattore di correzione

Quando hai avviato ``date'' sul cambio di minuto, la tua macchina era in ritardo o in anticipo? Se era in anticipo, dovrai sottrarre alcuni secondi, quindi annotateli come un numero negativo. Se era in ritardo, fai il contrario.

Adesso sottrai le due date. Se hai usato ``date +%j'', il numero rappresenta il giorno dell'anno (1-365, o 1-366 in quelli bisestili). Se hai operato a cavallo del 1� Gennaio, aggiungi 365 (o 366) al secondo numero. Se hai usato ``date +%s'' allora il tuo numero è in secondi, e dovrai dividerlo per 86400 per avere i giorni.

Se hai già un fattore di correzione in /etc/adjtime, dovrai tenere conto dei secondi che saranno già stati corretti. Se hai corretto in eccesso, questo numero avrà segno opposto di quello che hai appena misurato; se hai corretto in difetto, avrà lo stesso segno. Moltiplica il vecchio fattore di correzione per il numero di giorni, e aggiungi il nuovo numero di secondi (addizione con segno: se i due numeri hanno lo stesso segno, otterrai un numero più grande, altrimenti più piccolo).

Poi dividi il numero totale di secondi per i giorni per ottenere il nuovo fattore di correzione, ed immettilo in /etc/adjtime al posto del vecchio. Annotati la nuova data (in secondi o giorni) per la prossima volta.

Questo è come appare il mio /etc/adjtime:

-9.600000 845082716 -0.250655
(nota che 9.6 secondi al giorno sono quasi 5 minuti al mese!)

3. Alcune parole su xntpd

Il tuo sistema ha effettivamente due orologi: il ``real time clock'' (orologio in tempo reale) alimentato a batteria, che tiene il tempo quando il sistema è spento (conosciuto anche come ``CMOS clock'', ``Hardware clock'', o ``RTC'') ed il ``kernel time'' (orologio del kernel, qualche volta chiamato ``software clock'' o ``system clock''), che è basato sul timer interrupt ed è inizializzato dall'orologio CMOS al momento dell'avvio del sistema. Questi deviano con tassi diversi, quindi divergeranno gradualmente l'uno dall'altro, e anche dal tempo reale.

Tutti i riferimenti all'``orologio'' (the clock) nella documentazione di xntpd si riferiscono a quello del kernel. Quando avvii xntpd o timed (o qualsiasi altro programma che usi la chiamata di sistema adjtimex), il kernel di Linux assume che il 'suo' orologio sia più accurato di quello del CMOS, e reimposta quest'ultimo ogni 11 minuti da quel momento in poi (finché non si riavvia la macchina). Questo significa che ``clock'' non sa più quando l'orologio CMOS è stato regolato l'ultima volta, quindi non può usare il fattore di correzione in /etc/adjtime. Puoi usare ntpdate nel tuo file di avvio per regolare l'orologio da un timeserver prima di avviare xntpd. Se non hai un accesso continuo a un'accurata fonte di orario quando avvii la macchina, questo può essere un po' problematico: xntpd non è propriamente progettato per essere usato in tali situazioni.

xntpd include i driver per molti orologi radio, e può anche essere impostato per chiamare il servizio telefonico di NIST a intervalli regolari (assicurati di calcolare l'effetto sulla bolletta telefonica quando decidi l'intervallo tra le chiamate) (NdT: soprattutto se chiami dall'Italia!). Può anche applicare un fattore di correzione all'orologio del kernel se questo perde contatto con le sue sorgenti esterne per un certo periodo di tempo.

La maggior parte degli orologi radio costano $3-4000, ma puoi facilmente ottenere gli schemi di un poco costoso ``gadget box'' (effettivamente un modem a 300 baud) che stia tra il tuo computer e una qualunque radio ad onde corte regolata sul segnale orario della stazione del CHU in Canada (vedi ftp://ftp.udel.edu/pub/ntp/gadget.tar.Z). L'Heathkit WWV receiver (l'``Orologio più accurato'') è pure ancora disponibile (NdT: si parla del 1996), sebbene non sia un kit, e costa attorno ai $4-500. I segnali GPS contengono inoltre informazioni sull'orario, e alcuni ricevitori GPS possono essere collegati alla porta seriale. Questa potrebbe diventare la soluzione più a basso costo nel futuro.

In teoria, qualcuno potrebbe usare il segnale orario telefonico della NIST per calcolare automaticamente la deriva dell'orologio CMOS e di quello del kernel. Non conosco nessun programma singolo che lo faccia, ma probabilmente la maggior parte del codice potrebbe essere presa a prestito da xntpd.

Tradotto da Germano Rizzo, [email protected]