Thread (29 messages) 29 messages, 11 authors, 2008-12-22

RE: 12x performance drop on md/linux+sw raid1 due to barriers [xfs]

From: David Lethe <hidden>
Date: 2008-12-13 18:01:38
Also in: linux-xfs

-----Original Message-----
From: linux-raid-owner@vger.kernel.org [mailto:linux-raid-
owner@vger.kernel.org] On Behalf Of Martin Steigerwald
Sent: Saturday, December 13, 2008 11:26 AM
To: linux-xfs@oss.sgi.com
Cc: Justin Piszcz; Eric Sandeen; linux-raid@vger.kernel.org; Alan
Piszcz; xfs@oss.sgi.com
Subject: Re: 12x performance drop on md/linux+sw raid1 due to barriers
[xfs]

Am Samstag 13 Dezember 2008 schrieb Justin Piszcz:
quoted
On Sat, 6 Dec 2008, Eric Sandeen wrote:
quoted
Justin Piszcz wrote:
quoted
Someone should write a document with XFS and barrier support, if
I
quoted
quoted
quoted
recall, in the past, they never worked right on raid1 or raid5
devices, but it appears now they they work on RAID1, which slows
down performance ~12 times!!

There is some mention of it here:
http://oss.sgi.com/projects/xfs/faq.html#wcache_persistent

But basically I believe it should be noted in the kernel logs,
FAQ
quoted
quoted
quoted
or somewhere because just through the process of upgrading the
kernel, not changing fstab or any other part of the system,
performance can drop 12x just because the newer kernels implement
barriers.
Perhaps:

printk(KERN_ALERT "XFS is now looking after your metadata very
carefully; if you prefer the old, fast, dangerous way, mount with
-
o
quoted
quoted
nobarrier\n");

:)

Really, this just gets xfs on md raid1 in line with how it behaves
on most other devices.

But I agree, some documentation/education is probably in order; if
you choose to disable write caches or you have faith in the
battery
quoted
quoted
backup of your write cache, turning off barriers would be a good
idea.  Justin, it might be interesting to do some tests with:

barrier,   write cache enabled
nobarrier, write cache enabled
nobarrier, write cache disabled

a 12x hit does hurt though...  If you're really motivated, try the
same scenarios on ext3 and ext4 to see what the barrier hit is on
those as well.

-Eric
No, I have not forgotten about this I have just been quite busy, I
will test this now, as before, I did not use sync because I was in a
hurry and did not have the ability to test, I am using a different
machine/hw type but the setup is the same, md/raid1 etc.

Since I will only be measuring barriers, per esandeen@ I have
changed
quoted
the mount options from what I typically use to the defaults.
[...]
quoted
The benchmark:
# /usr/bin/time bash -c 'tar xf linux-2.6.27.8.tar; sync'
# echo 1 > /proc/sys/vm/drop_caches # (between tests)

== The tests ==

  KEY:
  barriers = "b"
  write_cache = "w"

  SUMMARY:
   b=on,w=on: 1:19.53 elapsed @ 2% CPU [BENCH_1]
  b=on,w=off: 1:23.59 elapsed @ 2% CPU [BENCH_2]
  b=off,w=on: 0:21.35 elapsed @ 9% CPU [BENCH_3]
b=off,w=off: 0:42.90 elapsed @ 4% CPU [BENCH_4]
This is quite similar to what I got on my laptop without any RAID
setup[1]. At least without barriers it was faster in all of my tar -xf
linux-2.6.27.tar.bz2 and rm -rf linux-2.6.27 tests.

At the moment it appears to me that disabling write cache may often
give more performance than using barriers. And this doesn't match my
expectation of write barriers as a feature that enhances performance.
Right now a "nowcache" option and having this as default appears to
make more sense than defaulting to barriers. But I think this needs
more testing than just those simple high meta data load tests. Anyway
I
am happy cause I have a way to speed up XFS ;-).

[1] http://oss.sgi.com/archives/xfs/2008-12/msg00244.html

Ciao,
--
Martin 'Helios' Steigerwald - http://www.Lichtvoll.de
GPG: 03B0 0D6C 0040 0710 4AFA  B82F 991B EAAC A599 84C7
Consider if write cache is enabled, and 128 blocks are in write cache
...
waiting to be flushed.

If those 128 blocks are not needed again before it is time to flush, 
then not only did you waste cycles copying those 128 blocks into cache,
but you prevented those same 128 block from being used by read cache,
buffers,
whatever..  You also have overhead of cache lookup, and no matter what,
you still
have to flush cache eventually.   If you are doing extended writes, then
the cache
will fill up quickly, so it hurts you.  Write cache is of greatest
benefit on a 
transactional environment, like database, and can hurt performance on
benchmarks,
rebuilds, etc .. depending on whether or not the extended operations can
actually 
save a disk I/O by getting information from the cache before it is time
to flush
cache to disk.

If you have SCSI, FC, or SAS disks, then you can query the drive's cache
log pages
(they are in vendor-specific fields for some drives), to see how the
cache is being
Utilized and determine relative efficiency.


David


Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help