From: Jeff Moyer on
Hi,

In testing iozone using the flag that enforces an fsync before close, we found
that performance for cfq on ext3 and ext4 file systems was very poor for file
sizes 8MB and below (as compared with a 2.6.18 kernel's cfq, or with a recent
kernel with deadline). The storage involved is middle of the road SAN storage
connected via a single fiber pair. Investigation showed that the idling logic
of cfq was causing the process issuing the I/O to stall. iozone, in this case,
was really dependant on the journal commits done by the jbd thread, but cfq
was instead idling waiting for more I/O from iozone. Setting slice_idle to
0 for cfq will regain this performance.

However, if you introduce a single sequential reader into the mix, even
with slice_idle set to 0, cfq is unable to perform as well as deadline:

deadline cfq, defaults cfq, slice_idle=0
fs_mark: 294.3 36.1 48.0
fio bsr: 153 MB/s 152 MB/s 147 MB/s

I used fs_mark to simulate iozone (it's less verbose) and fio to start
a single Buffered Sequential Reader (bsr). The fs_mark numbers are in
files/second. As you can see, cfq doesn't even compete here.

With either of the two patches applied, we get back a subset of the
performance. With both applied, we are in line with deadline. I've also
tested these patches against a single SATA disk and observed no performance
degradation for default tuning.

[PATCH 1/2] cfq: always return false from should_idle if slice_idle is set to zero
[PATCH 2/2] cfq: allow dispatching of both sync and async I/O together
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo(a)vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/