Re: [PATCH] mm: evict streaming IO cache first

From: Andrew Morton
Date: Sun Nov 16 2008 - 23:47:52 EST


On Sun, 16 Nov 2008 16:20:26 -0500 Rik van Riel <riel@xxxxxxxxxx> wrote:

> Linus Torvalds wrote:
> > On Sat, 15 Nov 2008, Andrew Morton wrote:
> >> Really, I think that the old approach of observing the scanner
> >> behaviour (rather than trying to predict it) was better.
> >
> > That's generally true. Self-adjusting behaviour rather than a-priori rules
> > would be much nicer. However, we apparently need to fix this some way.
> > Anybody willing to re-introduce some of the old logic?
>
> The old behaviour has big problems, especially on large memory
> systems. If the old behaviour worked right, we would not have
> been working on the split LRU code for the last year and a half.

Split LRU is (in this aspect) worse than the old code.

> Due to programs manipulating memory many pages at a time, the
> LRU ends up getting mapped and cache pages on the list in bunches.
>
> On large memory systems, after the scanner runs into a bunch
> of mapped pages, it will switch to evicting mapped pages, even
> if the next bunch of pages turns out to be cache pages.

Sure. But that sounds like theory to me. I've never seen anyone even
vaguely get anywhere near the level of instrumentation and
investigation and testing to be in a position to demonstrate that this
is a problem in practice.

> I am not convinced that "reacting to what happened in the last
> 1/4096th of the LRU" is any better than "look at the list stats
> and decide what to do".

I bet it is. The list stats are aggregated over the entire list and
aren't very useful for predicting the state of the few hundred pages at
the tail of the list.

> Andrew's objection to how things behave on small memory systems
> (the patch does not change anything) is valid, but going back
> to the old behaviour does not seem like an option to me, either.

There's also the behaviour change at the randomly-chosen
(nr[LRU_INACTIVE_FILE] == nr[LRU_ACTIVE_FILE) point..

> I will take a look at producing smoother self tuning behaviour
> in get_scan_ratio(), with logic along these lines:
> - the more file pages are inactive, the more eviction should
> focus on file pages, because we are not eating away at the
> working set yet
> - the more file pages are active, the more there needs to be
> a balance between file and anon scanning, because we are
> starting to get to the working sets for both

hm. I wonder if it would be prohibitive to say "hey, we did the wrong
thing in that scanning pass - rewind and try it again". Probably it
would be.

Anyway, we need to do something.

Shouldn't get_scan_ratio() be handling this case already?
--
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/