Details
-
Bug
-
Status: Closed
-
Major
-
Resolution: Fixed
-
None
-
None
-
New
Description
This method has a lot of problems:
1. it tracks 'stale files' as it writes (this seems pointless), and only actually fsyncs the intersection of that 'stale files' and the filenames passed as argument to sync(). So any bogus names passed to sync() are just silently ignored
2. if "something bad happens" (e.g. two indexwriters/dirs on the same path, or some other shenanigans), and the file is actually in stale files, but was say actually deleted on the filesystem, the underlying fsync() call will create a new 0-byte file and fsync that.
In my opinion we should do none of this. we should throw exceptions when this stuff is wrong.
Attachments
Attachments
Issue Links
- is related to
-
LUCENE-6150 Remove staleFiles set and onIndexOutputClosed from FSDirectory
- Closed
- is required by
-
LUCENE-5588 We should also fsync the directory when committing
- Closed