Date: Wed, 16 Jul 2008 07:49:03 -0700 (PDT) From: Barney Cordoba <barney_cordoba@yahoo.com> To: Steve Kargl <sgk@troutmask.apl.washington.edu> Cc: current@freebsd.org Subject: Re: ULE scheduling oddity Message-ID: <565436.13205.qm@web63915.mail.re1.yahoo.com> In-Reply-To: <20080715175944.GA80901@troutmask.apl.washington.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
--- On Tue, 7/15/08, Steve Kargl <sgk@troutmask.apl.washington.edu> wrote: > From: Steve Kargl <sgk@troutmask.apl.washington.edu> > Subject: ULE scheduling oddity > To: freebsd-current@freebsd.org > Date: Tuesday, July 15, 2008, 1:59 PM > It appears that the ULE scheduler is not providing a fair > slice to running processes. > > I have a dual-cpu, quad-core opteron based system with > node21:kargl[229] uname -a > FreeBSD node21.cimu.org 8.0-CURRENT FreeBSD 8.0-CURRENT #3: > Wed Jun 4 16:22:49 PDT 2008 > kargl@node10.cimu.org:src/sys/HPC amd64 > > If I start exactly 8 processes, each gets 100% WCPU > according to > top. If I add to additional processes, then I observe > > last pid: 3874; load averages: 9.99, 9.76, 9.43 up > 0+19:54:44 10:51:18 > 41 processes: 11 running, 30 sleeping > CPU: 100% user, 0.0% nice, 0.0% system, 0.0% interrupt, > 0.0% idle > Mem: 5706M Active, 8816K Inact, 169M Wired, 84K Cache, 108M > Buf, 25G Free > Swap: 4096M Total, 4096M Free > > PID USERNAME THR PRI NICE SIZE RES STATE C > TIME WCPU COMMAND > 3836 kargl 1 118 0 577M 572M CPU7 7 > 6:37 100.00% kzk90 > 3839 kargl 1 118 0 577M 572M CPU2 2 > 6:36 100.00% kzk90 > 3849 kargl 1 118 0 577M 572M CPU3 3 > 6:33 100.00% kzk90 > 3852 kargl 1 118 0 577M 572M CPU0 0 > 6:25 100.00% kzk90 > 3864 kargl 1 118 0 577M 572M RUN 1 > 6:24 100.00% kzk90 > 3858 kargl 1 112 0 577M 572M RUN 5 > 4:10 78.47% kzk90 > 3855 kargl 1 110 0 577M 572M CPU5 5 > 4:29 67.97% kzk90 > 3842 kargl 1 110 0 577M 572M CPU4 4 > 4:24 66.70% kzk90 > 3846 kargl 1 107 0 577M 572M RUN 6 > 3:22 53.96% kzk90 > 3861 kargl 1 107 0 577M 572M CPU6 6 > 3:15 53.37% kzk90 > > I would have expected to see a more evenly distributed WCPU > of around > 80% for each process. So, do I need to tune one or more of > the > following sysctl values? Is this a side effect of cpu > affinity > being a tad too aggressive? > > node21:kargl[231] sysctl -a | grep sched | more > kern.sched.preemption: 1 > kern.sched.steal_thresh: 3 > kern.sched.steal_idle: 1 > kern.sched.steal_htt: 1 > kern.sched.balance_interval: 133 > kern.sched.balance: 1 > kern.sched.affinity: 1 > kern.sched.idlespinthresh: 4 > kern.sched.idlespins: 10000 > kern.sched.static_boost: 160 > kern.sched.preempt_thresh: 64 > kern.sched.interact: 30 > kern.sched.slice: 13 > kern.sched.name: ULE > > -- > Steve > _______________________________________________ > freebsd-current@freebsd.org mailing list > http://lists.freebsd.org/mailman/listinfo/freebsd-current > To unsubscribe, send any mail to > "freebsd-current-unsubscribe@freebsd.org" I don't see why "equal" distribution is or should be a goal, as that does not guarantee optimization. Given that the cache is shared between only 2 cpus, it might very well be more efficient to run on 2 CPUs when the 3rd or 4th isn't needed. It works pretty darn well, IMO. Its not like your little app is the only thing going on in the system
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?565436.13205.qm>