[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <44FBFFFC.90309@tls.msk.ru>
Date: Mon, 04 Sep 2006 14:29:16 +0400
From: Michael Tokarev <mjt@....msk.ru>
To: Helge Hafting <helge.hafting@...el.hist.no>
CC: Marc Perkel <marc@...kel.com>, linux-kernel@...r.kernel.org
Subject: Re: Raid 0 Swap?
Helge Hafting wrote:
> Michael Tokarev wrote:
[]
>> If something with swap space goes wrong, God only knows what will break.
>> It is trivial to break userspace data this way, when an app is swapped
>> out and there's an error reading it from swap, its data file very likely
>> to be corrupt, especially when it is interrupted during file update.
>> It is probably possible to corrupt the whole filesystem this way too,
>> when some kernel memory has been swapped out and is needed to write some
>> parts of filesystem, but it can't be read back.
>>
> I thought kernel data weren't swapped at all?
> Mostly because kernel data could be needed immediately, with
> no option of waiting for swapin. So, bad swap should only really kill
> userspace programs,
> although it probably can cause some bad delays in cases
> where the userspace program calls into the kernel,
> passing an address that happens to be in damaged swap.
> You might then stall the kernel holding some resources
> while the disks retries umpteen times.
Well, it's not that simple. Kernel uses both swappable and
non-swappable memory internally. For some things, it's
unswappable, for some, it's swappable. In general, it's
impossible to say which parts of kernel will break (and
in wich ways) if swap goes havoc.
>> Ie, your swap space must be reliable. At least not worse than your
>> memory.
>> And with striping, you've much more chances of disk failure...
>> Yes it sounds very promising at first, to let kernel stripe swap space,
>> for faster operations. But hell, first, try to avoid swappnig in the
>> first place, by installing appropriate amount memory which is cheap
>> nowadays, so there will be just no need for swapping. And when it's
>> done, it's not relevant anymore whenever your swap space is fast or
>> not. But make it *reliable*.
>>
> Some swap is nice to have. "Ouch - sluggish server today,
> I will have to look into it" is so much better
> than "Eww - the OOM serial killer took out another 5 processes,
> people are screaming!"
I didn't say "eliminate swap space", I said about trying to avoid
swap usage. In the other words, DO set up swap space, and DO it
in a reliable way. Not "swap isn't needed" - well yes, it's
not entirely clear from my statement.
> As for reliable swap - swap on raid-1 is nice - and it
> probably perform better than single-disk swap too,
> although not as fast as striped swap.
Yes it's slower. But you don't really care, because in normal
life, there should be almost no swap usage. When swapping starts
occuring in amounts where speed difference is noticeable, it's
time to add more memory (or to run less hungry processes),
not to speed up swap space.
/mjt
--
VGER BF report: H 0.182426
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists