Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Are FileChannel.force and FileDescriptor.sync both needed?

Tags:

java

io

storage

nio

In https://stackoverflow.com/questions/730521/really-force-file-sync-flush-in-java, the author writes in the summary of the answers:

Use c.force(true) followed by s.getFD().sync() for Java NIO

My question is: do you really need both? Isn't force enough? Aren't force and sync just different interfaces for doing the same thing? I can't find anyplace where this is confirmed.

like image 613
njlarsson Avatar asked Feb 03 '23 19:02

njlarsson


1 Answers

My understanding is that the correct answer is No.

FileChannel.force calls fdatasync or fsync. This can be seen in jdk/src/solaris/native/sun/nio/ch/FileChannelImpl.c on of the OpenJDK source code. FileDescriptor calls fsync (To find this out was more complex. I finally traced it to jvm.cpp).

I am the "author" of the linked question. So I was wrong. What is NOT enough is FileOutputStream.flush. because it is a no-op. You therefore either need force or sync.

like image 185
dmeister Avatar answered Feb 11 '23 06:02

dmeister