Re: Why not always do copy-out in jbd2_journal_write_metadta_buffer

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Mon 22-10-18 10:34:48, Fisher wrote:
> Recently I was testing my storage's performance and found that there were
> periodic performance drops when I ran sequential write benchmark.
> After profiling the duration in each step, I found that the dropping
> performance was due to wait_on_bit_io(&bh->b_state, BH_Shadow,
> TASK_UNINTERRUPTIBLE) in do_get_write_access(). And this is what made me
> confused, if my understanding was right, I thought buffer_shadow(bh)
> stands for buffer not being copied-out that's why we should wait.

No buffer_shadow() just means that some version of the buffer is being
written to the journal. 

> But why don't we do copy-out in jbd2_journal_write_metadta_buffer()? and
> if we do do the copy-out, does that mean we don't have to
> set_buffer_shadow because it refers to buffer not copied-out?

The code in do_get_write_access() checks whether the buffer already has
frozen data (by checking jh->b_frozen_data) and if not, if it is just being
written to the journal (buffer_shadow() check in there). If it is, we have
to wait because we cannot modify the version of the buffer that goes to the
journal.

> I made a test, when a buffer_head goes into
> jbd2_journal_write_metadta_buffer(), as long as it belongs to metadata,
> then force it to do copy-out and do not set_buffer_shadow, then there
> will be no periodic performance drops. Is this test reasonable?

Well, it does trade of CPU overhead (you know copy buffer for each
transaction) for the latency (no need to wait for buffer writeout when
redirtying buffer). Usually I wouldn't consider this worth it but obviously
it depends on the workload...

								Honza
-- 
Jan Kara <jack@xxxxxxxx>
SUSE Labs, CR



[Index of Archives]     [Reiser Filesystem Development]     [Ceph FS]     [Kernel Newbies]     [Security]     [Netfilter]     [Bugtraq]     [Linux FS]     [Yosemite National Park]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Device Mapper]     [Linux Media]

  Powered by Linux