Fix missing Handle release in TableCache::GetRangeTombstoneIterator (#8589)
Summary: This appears to be little used code so not a major bug, but is blocking https://github.com/facebook/rocksdb/issues/8544 Pull Request resolved: https://github.com/facebook/rocksdb/pull/8589 Test Plan: Added regression test to the end of DBRangeDelTest::TableEvictedDuringScan. Without this fix, ASAN reports memory leak. Reviewed By: ajkr Differential Revision: D29943623 Pulled By: pdillinger fbshipit-source-id: f7115fa6d4440aef83888ff609aa03d09216463b
This commit is contained in:
parent
eec79b39a6
commit
e352bd5742
@ -660,6 +660,16 @@ TEST_F(DBRangeDelTest, TableEvictedDuringScan) {
|
|||||||
ASSERT_EQ(kNum, expected);
|
ASSERT_EQ(kNum, expected);
|
||||||
delete iter;
|
delete iter;
|
||||||
db_->ReleaseSnapshot(snapshot);
|
db_->ReleaseSnapshot(snapshot);
|
||||||
|
|
||||||
|
// Also test proper cache handling in GetRangeTombstoneIterator,
|
||||||
|
// via TablesRangeTombstoneSummary. (This once triggered memory leak
|
||||||
|
// report with ASAN.)
|
||||||
|
opts.max_open_files = 1;
|
||||||
|
Reopen(opts);
|
||||||
|
|
||||||
|
std::string str;
|
||||||
|
ASSERT_OK(dbfull()->TablesRangeTombstoneSummary(db_->DefaultColumnFamily(),
|
||||||
|
100, &str));
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(DBRangeDelTest, GetCoveredKeyFromMutableMemtable) {
|
TEST_F(DBRangeDelTest, GetCoveredKeyFromMutableMemtable) {
|
||||||
|
@ -297,6 +297,7 @@ Status TableCache::GetRangeTombstoneIterator(
|
|||||||
const InternalKeyComparator& internal_comparator,
|
const InternalKeyComparator& internal_comparator,
|
||||||
const FileMetaData& file_meta,
|
const FileMetaData& file_meta,
|
||||||
std::unique_ptr<FragmentedRangeTombstoneIterator>* out_iter) {
|
std::unique_ptr<FragmentedRangeTombstoneIterator>* out_iter) {
|
||||||
|
assert(out_iter);
|
||||||
const FileDescriptor& fd = file_meta.fd;
|
const FileDescriptor& fd = file_meta.fd;
|
||||||
Status s;
|
Status s;
|
||||||
TableReader* t = fd.table_reader;
|
TableReader* t = fd.table_reader;
|
||||||
@ -308,8 +309,15 @@ Status TableCache::GetRangeTombstoneIterator(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (s.ok()) {
|
if (s.ok()) {
|
||||||
|
// Note: NewRangeTombstoneIterator could return nullptr
|
||||||
out_iter->reset(t->NewRangeTombstoneIterator(options));
|
out_iter->reset(t->NewRangeTombstoneIterator(options));
|
||||||
assert(out_iter);
|
}
|
||||||
|
if (handle) {
|
||||||
|
if (*out_iter) {
|
||||||
|
(*out_iter)->RegisterCleanup(&UnrefEntry, cache_, handle);
|
||||||
|
} else {
|
||||||
|
ReleaseHandle(handle);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user