Close file to avoid file-descriptor leakage (#6936)

Summary:
When operation on an open file descriptor fails, we should close the file descriptor.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/6936

Test Plan: make check

Reviewed By: pdillinger

Differential Revision: D21885458

Pulled By: riversand963

fbshipit-source-id: ba077a76b256a8537f21e22e4ec198f45390bf50
main
Yanqin Jin 5 years ago committed by Facebook GitHub Bot
parent 6cbe9d9762
commit a8170d774c
  1. 1
      HISTORY.md
  2. 10
      env/fs_posix.cc

@ -11,6 +11,7 @@
* Let best-efforts recovery ignore corrupted files during table loading. * Let best-efforts recovery ignore corrupted files during table loading.
* Fix corrupt key read from ingested file when iterator direction switches from reverse to forward at a key that is a prefix of another key in the same file. It is only possible in files with a non-zero global seqno. * Fix corrupt key read from ingested file when iterator direction switches from reverse to forward at a key that is a prefix of another key in the same file. It is only possible in files with a non-zero global seqno.
* Fix abnormally large estimate from GetApproximateSizes when a range starts near the end of one SST file and near the beginning of another. Now GetApproximateSizes consistently and fairly includes the size of SST metadata in addition to data blocks, attributing metadata proportionally among the data blocks based on their size. * Fix abnormally large estimate from GetApproximateSizes when a range starts near the end of one SST file and near the beginning of another. Now GetApproximateSizes consistently and fairly includes the size of SST metadata in addition to data blocks, attributing metadata proportionally among the data blocks based on their size.
* Fix potential file descriptor leakage in PosixEnv's IsDirectory() and NewRandomAccessFile().
### Public API Change ### Public API Change
* Flush(..., column_family) may return Status::ColumnFamilyDropped() instead of Status::InvalidArgument() if column_family is dropped while processing the flush request. * Flush(..., column_family) may return Status::ColumnFamilyDropped() instead of Status::InvalidArgument() if column_family is dropped while processing the flush request.

10
env/fs_posix.cc vendored

@ -241,6 +241,8 @@ class PosixFileSystem : public FileSystem {
s = IOError("while mmap file for read", fname, errno); s = IOError("while mmap file for read", fname, errno);
close(fd); close(fd);
} }
} else {
close(fd);
} }
} else { } else {
if (options.use_direct_reads && !options.use_mmap_reads) { if (options.use_direct_reads && !options.use_mmap_reads) {
@ -889,14 +891,16 @@ class PosixFileSystem : public FileSystem {
if (fd < 0) { if (fd < 0) {
return IOError("While open for IsDirectory()", path, errno); return IOError("While open for IsDirectory()", path, errno);
} }
IOStatus io_s;
struct stat sbuf; struct stat sbuf;
if (fstat(fd, &sbuf) < 0) { if (fstat(fd, &sbuf) < 0) {
return IOError("While doing stat for IsDirectory()", path, errno); io_s = IOError("While doing stat for IsDirectory()", path, errno);
} }
if (nullptr != is_dir) { close(fd);
if (io_s.ok() && nullptr != is_dir) {
*is_dir = S_ISDIR(sbuf.st_mode); *is_dir = S_ISDIR(sbuf.st_mode);
} }
return IOStatus::OK(); return io_s;
} }
FileOptions OptimizeForLogWrite(const FileOptions& file_options, FileOptions OptimizeForLogWrite(const FileOptions& file_options,

Loading…
Cancel
Save