[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <EF21BE9C-2457-4C17-A667-9839E23C58B8@mit.edu>
Date: Sat, 22 Jan 2011 14:37:19 -0500
From: Theodore Tso <tytso@....EDU>
To: torn5 <torn5@...ftmail.org>
Cc: Josef Bacik <josef@...hat.com>,
Jon Leighton <j@...athanleighton.com>,
linux-ext4@...r.kernel.org
Subject: Re: Severe slowdown caused by jbd2 process
On Jan 22, 2011, at 11:21 AM, torn5 wrote:
>
> I'd have a different question now:
> Is the fsync in a nobarrier mount totally swallowed?
No. It will still cause a journal commit, and send disk writes down to the HDD. How those disk writes will be interpreted by the HDD is completely up to the HDD's firmware. It could seek like mad and try to write all of those disk blocks as they arrive, or it could try to batch writes which are farther away to minimize disk head movement, and perhaps combine writes that arrive potentially seconds or minutes apart.
> If not:
> a) what guarantees does it provide in a nobarrier situation and
As long as there is not a power failure (or disk failure, of couse), those disk writes will eventually hit the platter. The data should be consistent on disk if the kernel were to panic, or someone were to hit the reset button. So you will have at least that level of guarantee. But if the power cord gets kicked out of the wall, or the floor waxer in the data center causes the circuit breaker to pop, or the flood waters in Queensland start pouring into the underground car park and the transformer locater in said car park shorts out, you have no guarantees at all.
> b) is there a "fakefsync" mount option or some other way to make it a no-op? (I understand the risk, and the fact that this is actually a change in the application's logic)
No, sorry. Usually the fsync is there for a good reason, and if fsync's are completely eliminated, you have absolutely no guarantees at all. (Kernel panics, reset buttons, etc., all will cause the database to be totally scrambled.) Providing such a knob to system administrators who might use it to "speed up" their application, is considered a bit of an attractive nuisance --- short of like providing a button with an LED display that says in bright green friendly colors, "push to test", and then once pushed, changes to an angry red color, "release to detonate". :-)
You can hack the kernel to do that, though. Someone who is bright enough to figure out how to create their own fake-fsync mount option is hopefully smart enough to understand the consequences of doing that. (Just like someone who can figure out how to defeat the safety mechanisms on a lawn mower, and then uses a lawn mower to trim a hedge, is hopefully enough to understand the consequences of what happens if he drops said lawn mower on his foot and loses it.)
The smart, thing, of course, is to write your application logic in a way that doesn't cause so many database transactions.
-- Ted
> --
> To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists