From owner-freebsd-questions Fri Mar 12 20:24:55 1999 Delivered-To: freebsd-questions@freebsd.org Received: from alpha.comkey.com.au (alpha.comkey.com.au [203.9.152.215]) by hub.freebsd.org (Postfix) with SMTP id 97D5E14D85 for ; Fri, 12 Mar 1999 20:23:51 -0800 (PST) (envelope-from gjb@comkey.com.au) Received: (qmail 4100 invoked by uid 1001); 13 Mar 1999 03:51:57 -0000 Message-ID: <19990313035157.4099.qmail@alpha.comkey.com.au> X-Posted-By: GBA-Post 1.04 06-Feb-1999 X-PGP-Fingerprint: 5A91 6942 8CEA 9DAB B95B C249 1CE1 493B 2B5A CE30 Date: Sat, 13 Mar 1999 13:51:57 +1000 From: Greg Black To: Thomas Schuerger Cc: freebsd-questions@FreeBSD.ORG, freebsd-bugs@FreeBSD.ORG Subject: Re: Scheduling bug? References: <199903111631.RAA03067@wurzelausix.cs.uni-sb.de> In-reply-to: <199903111631.RAA03067@wurzelausix.cs.uni-sb.de> of Thu, 11 Mar 1999 17:31:11 +0100 Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Sender: owner-freebsd-questions@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG > > > > When having two processes running, one with nice-level 0, > > > > the other one with nice-level 19 and both consuming as much > > > > CPU time as possible (e.g. an endless loop), FreeBSD will do > > > > a 2:1 time-slicing (that is, the first process will get 66% > > > > of the CPU-time and the other one 33%). For a test, just > > > > start two Perl processes doing a "while(1) {}", renice one > > > > of the processes to 19 and watch the "top" output. > > > > [...] > > > > > It's impossible given the test that you created to accurately > > > _measure_ this difference, as you're relying on an interpreted > > > (perl) loop - I'd be interested to see the same results with an > > > executable that was looping - so as to remove the layer of the > > > interpreter. > > > > The real point is that top is a useless tool when it comes to > > this kind of comparisons. You're just as likely seeing > > variations in the performance of top, as learning anything about > > the actual time slices. > > > > FreeBSD may suck in this area, but you'd have to do some proper > > testing to find out. This means writing some code that does > > useful work (never busy loops) and measuring the amount of work > > that gets done. It's harder than it sounds. > > I'd say that this is proper testing. I am running the RC5 keycrack > client in the background (www.distributed.net), which can be > considered as being an endless loop with no disk/network i/o > (disk/network is accessed once within some hours). > The process is automatically running with nice-level 19. > > Now, anything that's cpu-intensive in the foreground (e.g. compilation, > GIMP or whatever) will get only 66% of the cpu-time, because the > background process is not scheduled properly (this is not a matter > of what 'top' displays, it's what can really be measured when e.g. > applying effects in GIMP to an image). Even when doing disk > i/o in the foreground, like when rebuilding the 'locate' database, > this will be a lot slower. When killing the background process while > rebuilding the 'locate' database, the harddisk accesses are much more > frequent and it terminates a lot earlier. This story is very different from the information that was first posted and points to the reason why people constantly advise you to post all the relevant information in the first place so that other people won't waste their time answering questions that turn out not to be the real question. I don't have time to look at real examples right now, but I'd agree that the behaviour you describe here is far from optimal, assuming the picture you paint is accurate. -- Greg Black To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-questions" in the body of the message