Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 16 Dec 1999 18:32:44 +0100
From:      Poul-Henning Kamp <phk@critter.freebsd.dk>
To:        nate@mt.sri.com (Nate Williams)
Cc:        Kevin Day <toasty@dragondata.com>, dillon@apollo.backplane.com (Matthew Dillon), gallatin@cs.duke.edu (Andrew Gallatin), freebsd-current@FreeBSD.ORG
Subject:   Re: Serious server-side NFS problem 
Message-ID:  <16722.945365564@critter.freebsd.dk>
In-Reply-To: Your message of "Thu, 16 Dec 1999 10:18:48 MST." <199912161718.KAA19547@mt.sri.com> 

next in thread | previous in thread | raw e-mail | index | archive | help
In message <199912161718.KAA19547@mt.sri.com>, Nate Williams writes:
>> In message <199912160758.BAA87332@celery.dragondata.com>, Kevin Day writes:
>> 
>> >Ack, I was using this very same thing for several devices in an isolated
>> >peer-to-peer network to decide who the 'master' was. (Whoever had been up
>> >longest knew more about the state of the network) Having this change could
>> >cause weirdness for me too... I assumed (without checking *thwap*) that
>> >boottime was a constant.
>> >
>> >Perhaps a 'real_boottime' or 'unadjusted_boottime' that gets copied after
>> >'boottime' gets initialized so that others can use it, not just NFS? :)
>> 
>> no, I think that is a bad idea.  In your case you want to use the
>> "uptime" which *is* a measure of how long the system has been
>> running.
>
>Uptime is also a constantly changing number.  Forgive me for my
>ignorance, but why does bootime constantly change?  I would have thought
>it would be a constant?  I've got software that also uses this to
>determine when a new copy of it exists (although I do keep a local cache
>of the value in case my software crashes, since it can recover from a
>crash, but not a reboot).
>
>I would think that boottime would be constant, since you didn't keep
>booting at a different time...

Well, our timekeeping is done my having two estimates:  The amount of
time on the UTC timescale since we booted and the time we did so in
UTC.

If people do a "settimeofday" we change the boot time since the
amount of time we've been up *IS* known for sure, whereas the boottime
is only an estimate.

The ntp pll adjusts the frequency of our clock, since that is a
frequency adjustment.

The sticky but is the gross "adjtime" call.  Since the primary user
of this is the timed daemon, which issues phase adjustments, not
frequency adjustments, it fiddles boottime, but still using the
"slowly converge" method so we don't step the clock more than we
need to.

The reason why xntpd used tickadj was that enabling the kernel
pll for xntpd was rather obscure and people never did.  This problem
is now gone with NTPv4 (Thanks Roberto!)

So after today, the problem is gone, unless you use timed/tickadj
or other broken clock synchronizers.

--
Poul-Henning Kamp             FreeBSD coreteam member
phk@FreeBSD.ORG               "Real hackers run -current on their laptop."
FreeBSD -- It will take a long time before progress goes too far!


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?16722.945365564>