FSImage writing should always fsync before close
------------------------------------------------

                 Key: HDFS-970
                 URL: https://issues.apache.org/jira/browse/HDFS-970
             Project: Hadoop HDFS
          Issue Type: Bug
          Components: name-node
    Affects Versions: 0.20.1, 0.21.0, 0.22.0
            Reporter: Todd Lipcon
            Assignee: Todd Lipcon
            Priority: Critical


Without an fsync, it's common that filesystems will delay the writing of 
metadata to the journal until all of the data blocks have been flushed. If the 
system crashes while the dirty pages haven't been flushed, the file is left in 
an indeterminate state. In some FSs (eg ext4) this will result in a 0-length 
file. In others (eg XFS) it will result in the correct length but any number of 
data blocks getting zeroed. Calling FileChannel.force before closing the 
FSImage prevents this issue.

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to