From: Andrzej Szymanski <szymans@agh.edu.pl>
To: linux-kernel@vger.kernel.org
Subject: Strange write starvation on 2.6.17 (and other) kernels
Date: Mon, 14 Aug 2006 18:36:44 +0200 [thread overview]
Message-ID: <44E0A69C.5030103@agh.edu.pl> (raw)
Hi,
I've encountered a strange problem - if an application is sequentially
writing a large file on a busy machine, a single write() of 64KB may
take even 30 seconds. But if I do fsync() after each write() the maximum
time of write()+fsync() is about 0.5 second (the overall performance is,
of course, degraded).
The point is, that some applications (samba+smbclient) time out after
20s waiting for write().
Does anybody have an idea how to tune the kernel to avoid this strange
delay in write()?
I've tried to experiment with cfq and deadline IO scheduler - without
success. Decreasing /proc/vm/dirty_ratio to 5% helps a little.
If somebody want to test it, the tool I've written for measuring maximum
write() time is here: http://galaxy.agh.edu.pl/~szymans/writetimer
1. Compile writetimer.c
2. Put a large background read from the disk
3. Simultaneously write 10 files 200MB each (write() without fsync())
for i in 1 2 3 4 5 6 7 8 9 0 ; do ./writetimer 200 > testfile$i & done
4. and with fsync() after each write()
for i in 1 2 3 4 5 6 7 8 9 0 ; do ./writetimer -200 > testfile$i & done
(negative file size turns on fsync())
Tested on
- 2.6.15-23 (512MB RAM, Pentium-M 1.7, Ubuntu 6.06, ATA disk)
- 2.6.17-1.2145_FC5 (512MB RAM, Pentium-M 1.7, Fedora Core 5, ATA disk)
- 2.6.12-2.3.legacy_FC3smp (2GB RAM, Fedora Core 3, software RAID 5 on 4
ATA disks)
Thanks,
Andrzej
next reply other threads:[~2006-08-14 16:36 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-08-14 16:36 Andrzej Szymanski [this message]
2006-08-14 18:46 ` Strange write starvation on 2.6.17 (and other) kernels Jeff V. Merkey
2006-08-14 23:28 ` Grant Coady
2006-08-15 7:50 ` Andrew Morton
2006-08-15 7:51 ` Andrew Morton
2006-08-15 12:40 ` Grzegorz Kulewski
2006-08-15 14:04 ` Andrew Morton
2006-08-15 18:40 ` Jason Lunz
2006-08-16 20:54 ` Andrzej Szymanski
2006-08-17 8:36 ` Miquel van Smoorenburg
2006-08-21 1:31 ` Neil Brown
2006-08-21 12:40 ` Andrzej Szymanski
2006-08-22 7:40 ` Neil Brown
2006-08-25 5:41 ` Neil Brown
2006-08-25 8:46 ` Andrzej Szymanski
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=44E0A69C.5030103@agh.edu.pl \
--to=szymans@agh.edu.pl \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox