So what do you do when your PC doesn't know what time it is?
One of my Linux servers was misbehaving; even with NTP installed, it was drifting out of time sync with depressing regularity. The dreaded "Frequency error -512 PPM exceeds tolerance 500 PPM" explained that NTP was refusing to even consider adjusting the time on such a deeply broken system. And the clock was drifting into la-la-land whenever I didn't reset it for a week.
It would have been easy to buckle under and add a cron job to just sync the time every 5 minutes - but I just couldn't believe there wasn't another solution. So today, after watching this problem for (literally) years, I sat down and started Googling for the answer.
An hour later, the win was in: There is a magic utility in the distro (but not installed by default!) called "adjtimex", which brutally and forcefully corrects the clock rate for you. If you have a clock that is fast by 500 parts per million (43 seconds per day), just enter this magic command:
adjtimex --tick 9995
What this will do is to tell the kernel that every time your system thinks that 10 milliseconds have passed by, and it should count up the clock by this much, it should instead add 9.995 milliseconds to the clock. Losing that magic 500 ppm (0.05%) every single clock tick, and getting the clock back in touch with reality.
The adjtimex program has more options than this, including "--print", which is very useful for seeing what the variables are before you start playing with them - always a wise move.
And the NTP daemon actually plays with another of the variables that adjtimex can touch: the "frequency" variable - making small adjustments to the clock that will ensure that you are JUST in sync.
You can watch it being adjusted with this little command line:
while true; do date; adjtimex --print | grep frequency; sleep 300; done
This will then print a line every 5 minutes, showing how the frequency changes up and down as the NTP daemon hunts for the optimal value.
And now my clocks will be all right. I'm happy!
Wednesday, March 7, 2007
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment