From owner-freebsd-current Wed Jul 18 15:10:18 2001 Delivered-To: freebsd-current@freebsd.org Received: from salmon.maths.tcd.ie (salmon.maths.tcd.ie [134.226.81.11]) by hub.freebsd.org (Postfix) with SMTP id 2894437B405 for ; Wed, 18 Jul 2001 15:10:09 -0700 (PDT) (envelope-from iedowse@maths.tcd.ie) Received: from walton.maths.tcd.ie by salmon.maths.tcd.ie with SMTP id ; 18 Jul 2001 23:10:08 +0100 (BST) To: Bruce Evans Cc: freebsd-current@FreeBSD.ORG Subject: Re: Load average synchronisation and phantom loads In-Reply-To: Your message of "Wed, 18 Jul 2001 22:13:21 +1000." Date: Wed, 18 Jul 2001 23:10:02 +0100 From: Ian Dowse Message-ID: <200107182310.aa89902@salmon.maths.tcd.ie> Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG In message , Bruce Ev ans writes: >On Tue, 17 Jul 2001, Ian Dowse wrote: >> effect in the load calculation, but even for the shorter 5-minute >> timescale, this will average out to typically no more than a few >> percent (i.e the "5 minutes" will instead normally be approx 4.8 >> to 5.2 minutes). Apart from a marginally more wobbley xload display, >> this should not make any real difference. > >It should average out to precisely the same as before if you haven't >changed the mean (mean = average :-). The real difference may be >small, but I think it is an unnecessary regression. I meant the "5-minute average" that is computed; it will certainly not be precicely the same as before, though it will be similar. >from 0 very fast. Even with a large variation, the drift might not be >fast enough. Actually, it's not too bad with a +-1 second variation, which is why I chose a value that large. If you plot 60 samples (60 is the number of 5-second intervals in the 5-minute load average timescale) you get a relatively good dispersion of points throughout the 5-second interval. Try pasting the following into gnuplot a few times: plot [] [-2.5:2.5] \ "1){}select(undef,undef,undef,2.5)}' (5-second period, 50% duty cycle) then the interference pattern resulting from a +-1 tick variation has a period that is typically days long! Of course the interference pattern caused by the above script has an infinitely long period with the old load average calculation; it always causes an additional load of 1.0 even though the %CPU usage is approx 50%. >> The alternative that I considered was to sample the processes once >> during every 5-second interval, but to place the sampling point >> randomly over the interval. That probably results in a better > >I rather like this. With immediate update, It's almost equivalent to >your current method with a random variation of between -5 and 5 seconds >instead of between -1 and 1 seconds. Your current method doesn't >really reduce the jitter -- it just concentrates it into a smaller >interval. When I tried this approach (with immediate update), I didn't like the jumpyness of the load average. Instead of the relatively smooth decay that I'm used to, the way it sometimes changed twice in short succession and sometimes did not change for nearly 10 seconds was quite noticable. I'd be quite happy to go with the delayed version of this, though it does mean having two timer routines, and storing the `nrun' somewhere between samples and updates. >hopefully rare. Use a (small) random variation to reduce phase effects >for such processes. I think there are none in the kernel. I would try >using the following magic numbers: > > sample interval = 5.02 seconds (approx) (not 5.01, so that the random > variation never gives a multiple > of 1.00) > random variation = 0+-0.01 seconds (approx) > cexp[] = adjusted for 5.02 instead of 5.00 See above. I really want to try and avoid _any_ significant synchronisation effects, not just those that are caused by the kernel or by applications that happen to have a run pattern with a period of N * 1.0 seconds. Ian To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message