Re: time tells all about kernel VM's

safemode (safemode@speakeasy.net)
Tue, 23 Oct 2001 19:22:15 -0400


On Tuesday 23 October 2001 15:30, bill davidsen wrote:
> In article <3BD51F02.92B9B7F3@idb.hist.no>,
>
> Helge Hafting <helgehaf@idb.hist.no> wrote:
> | Any VM with paging _can_ be forced into a trashing situation where
> | a keypress takes hours to process. A better VM will take more pressure
> | before it gets there and performance will degrade more gradually.
> | But any VM can get into this situation.
>
> So far I agree, and that implies that the VM needs to identify and
> correct the situation.
The real reason i brought this up is because so much trouble was taken to
implement an OOM handler yet this obviously known and simple situation
totally bypasses it. What situation does the OOM handler even work at? I
would think that if anything actually tried mapping all of free memory,
anything else would error out and you'd just move to one of the terminals
open and kill the process.
The only situation i can think of that the OOM would come into use is leaking
memory but isn't that the same situation that I discribed occuring? What's
different? And how is it that the kernel creating 600MB of buffer was
normal instead of keeping some so my other programs could stay alive? Or
would it have not even mattered since there is a problem rooted in the vm io
subsystem that allows situations like this?
Also, is the idea of preemption in the VM being thought of for 2.5? Seems
like something like that would make this kind of problem mute.

I'm tempted to test out Andrea's vm to see if it locks just as easily.

> | Swapping out whole processes can help this, but it will merely
> | move the point where you get stuck. A load control system that
> | kills processes when response is too slow is possible, but
> | the problem here is that you can't get people to agree
> | on how bad is too bad. It is sometimes ok to leave the machine
> | alone crunching a big problem over the weekend. And sometimes
> | you _need_ response much faster.
> |
> | And what app to kill in such a situation?
> | You had a single memory pig, but it aint necessarily so.
>
> I think the problem is not killing the wrong thing, but not killing
> anything... We can argue any old factors for selection, but I would
> first argue that the real problem is that nothing was killed because the
> problem was not noticed.
>
> One possible way to recognize the problem is to identify the ratio of
> page faults to time slice used and assume there is trouble in River City
> if that gets high and stays high. I leave it to the VM gurus to define
> "high," but processes which continually block for page fault as opposed
> to i/o of some kind are an indication of problems, and likely to be a
> factor in deciding what to kill.
>
> I think it gives a fair indication of getting things done or not, and I
> have said before I like per-process page fault rates as a datam to be
> included in VM decisions.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/