Re: vmstat: On demand vmstat workers V4
From: Christoph Lameter
Date: Fri May 09 2014 - 10:53:53 EST
On Fri, 9 May 2014, Thomas Gleixner wrote:
> > > +/*
> > > + * Return a cpu number that may be used to run housekeeping
> > > + * tasks. This is usually the timekeeping cpu unless that
> > > + * is not available. Then we simply fall back to the current
> > > + * cpu.
> > > + */
> >
> > This comment is unusably vague. What the heck is a "housekeeping
> > task"? Why would anyone call this and what is special about the CPU
> > number it returns?
I just need a processor that keeps watch over the vmstat workers in the
system. The processor that does timekeeping is an obvious choice. I am
open to other suggestions.
Typically our system have processors that are used for OS processing and
processor that are focused on app services. Those need to be as
undisturbed as possible.
> >
> >
> > > +int tick_get_housekeeping_cpu(void)
> > > +{
> > > + int cpu;
> > > +
> > > + if (system_state < SYSTEM_RUNNING || tick_do_timer_cpu < 0)
> > > + cpu = raw_smp_processor_id();
>
> That's completely bogus. The system state check is pointless and
> tick_do_timer_cpu even more so because if you call that code from a
> worker thread tick_do_timer_cpu should be assigned to some cpu.
>
> Aside of that I'm having a hard time to understand why this stuff
> wants to move around at all.
>
> I think we agreed long ago, that for the whole HPC FULL_NOHZ stuff you
> have to sacrify at least one CPU for housekeeping purposes of all
> kinds, timekeeping, statistics and whatever.
Ok how do I figure out that cpu? I'd rather have a specific cpu that
never changes.
> So if you have a housekeeper, then it makes absolutely no sense at all
> to move it around in circles.
>
> Can you please enlighten me why we need this at all?
The vmstat kworker thread checks every 2 seconds if there are vmstat
updates that need to be folded into the global statistics. This is not
necessary if the application is running and no OS services are being used.
Thus we could switch off vmstat updates and avoid taking the processor
away from the application.
This has also been noted by multiple other people at was brought up at the
mm summit by others who noted the same issues.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/