ext3: Speedup WB_SYNC_ALL pass
authorJan Kara <jack@suse.cz>
Tue, 4 Mar 2014 10:52:16 +0000 (11:52 +0100)
committerJan Kara <jack@suse.cz>
Wed, 12 Mar 2014 21:48:02 +0000 (22:48 +0100)
commit2299432e1950c9ac0aa649d4617374ea24b6f131
tree8a376b4a81039ab5d0cd739aed46b0272f1f792c
parentcbcf27a9927e32931389980ee770f206377eb21b
ext3: Speedup WB_SYNC_ALL pass

When doing filesystem wide sync, there's no need to force transaction
commit separately for each inode because ext3_sync_fs() takes care of
forcing commit at the end. Most of the time this slowness doesn't
manifest because previous WB_SYNC_NONE writeback doesn't leave much to
write but when there are processes aggressively creating new files and
several filesystems to sync, the sync slowness can be noticeable. In the
following test script sync(1) takes around 6 minutes when there are two
ext3 filesystems mounted on a standard SATA drive. After this patch sync
is about twice as fast in the default data=ordered mode. For
data=writeback mode we have even bigger speedup.

function run_writers
{
  for (( i = 0; i < 10; i++ )); do
    mkdir $1/dir$i
    for (( j = 0; j < 40000; j++ )); do
      dd if=/dev/zero of=$1/dir$i/$j bs=4k count=4 &>/dev/null
    done &
  done
}

for dir in "$@"; do
  run_writers $dir
done

sleep 40
time sync

Signed-off-by: Jan Kara <jack@suse.cz>
fs/ext3/inode.c