ext4: Speedup WB_SYNC_ALL pass called from sync(2)
authorJan Kara <jack@suse.cz>
Tue, 4 Mar 2014 15:50:50 +0000 (10:50 -0500)
committerTheodore Ts'o <tytso@mit.edu>
Tue, 4 Mar 2014 15:50:50 +0000 (10:50 -0500)
commit10542c229a4e8e25b40357beea66abe9dacda2c0
tree7ae7251bfd1da2cb97a53883ae5eb6490c18415e
parent9eb79482a97152930b113b51dff530aba9e28c8e
ext4: Speedup WB_SYNC_ALL pass called from sync(2)

When doing filesystem wide sync, there's no need to force transaction
commit (or synchronously write inode buffer) separately for each inode
because ext4_sync_fs() takes care of forcing commit at the end (VFS
takes care of flushing buffer cache, respectively). 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 ext4 filesystems mounted on a standard SATA
drive. After this patch sync takes a couple of seconds so we have about
two orders of magnitude improvement.

      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>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
fs/ext4/inode.c