BlobDB: only compare CF IDs when checking whether an API call is for the default CF (#6226)

Summary:
BlobDB currently only supports using the default column family. The earlier
code enforces this by comparing the `ColumnFamilyHandle` passed to the
`Get`/`Put`/etc. call with the handle returned by `DefaultColumnFamily`
(which, at the end of the day, comes from `DBImpl::default_cf_handle_`).
Since other `ColumnFamilyHandle`s can also point to the default column
family, this can reject legitimate requests as well. (As an example,
with the earlier code, the handle returned by `BlobDB::Open` cannot
actually be used in API calls.) The patch fixes this by comparing only
the IDs of the column family handles instead of the pointers themselves.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/6226

Test Plan: `make check`

Differential Revision: D19187461

Pulled By: ltamasi

fbshipit-source-id: 54ce2e12ebb1f07e6d1e70e3b1e0213dfa94bda2
This commit is contained in:
Levi Tamasi 2019-12-19 18:03:24 -08:00
parent d84805962d
commit 7168d16103
3 changed files with 9 additions and 8 deletions

View File

@ -5,6 +5,7 @@
* Fixed two performance issues related to memtable history trimming. First, a new SuperVersion is now created only if some memtables were actually trimmed. Second, trimming is only scheduled if there is at least one flushed memtable that is kept in memory for the purposes of transaction conflict checking. * Fixed two performance issues related to memtable history trimming. First, a new SuperVersion is now created only if some memtables were actually trimmed. Second, trimming is only scheduled if there is at least one flushed memtable that is kept in memory for the purposes of transaction conflict checking.
* BlobDB no longer updates the SST to blob file mapping upon failed compactions. * BlobDB no longer updates the SST to blob file mapping upon failed compactions.
* Fix a bug in which a snapshot read through an iterator could be affected by a DeleteRange after the snapshot (#6062). * Fix a bug in which a snapshot read through an iterator could be affected by a DeleteRange after the snapshot (#6062).
* Fixed a bug where BlobDB was comparing the `ColumnFamilyHandle` pointers themselves instead of only the column family IDs when checking whether an API call uses the default column family or not.
## 6.6.0 (11/25/2019) ## 6.6.0 (11/25/2019)
### Bug Fixes ### Bug Fixes

View File

@ -87,7 +87,7 @@ class BlobDB : public StackableDB {
virtual Status Put(const WriteOptions& options, virtual Status Put(const WriteOptions& options,
ColumnFamilyHandle* column_family, const Slice& key, ColumnFamilyHandle* column_family, const Slice& key,
const Slice& value) override { const Slice& value) override {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }
@ -98,7 +98,7 @@ class BlobDB : public StackableDB {
virtual Status Delete(const WriteOptions& options, virtual Status Delete(const WriteOptions& options,
ColumnFamilyHandle* column_family, ColumnFamilyHandle* column_family,
const Slice& key) override { const Slice& key) override {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }
@ -111,7 +111,7 @@ class BlobDB : public StackableDB {
virtual Status PutWithTTL(const WriteOptions& options, virtual Status PutWithTTL(const WriteOptions& options,
ColumnFamilyHandle* column_family, const Slice& key, ColumnFamilyHandle* column_family, const Slice& key,
const Slice& value, uint64_t ttl) { const Slice& value, uint64_t ttl) {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }
@ -125,7 +125,7 @@ class BlobDB : public StackableDB {
virtual Status PutUntil(const WriteOptions& options, virtual Status PutUntil(const WriteOptions& options,
ColumnFamilyHandle* column_family, const Slice& key, ColumnFamilyHandle* column_family, const Slice& key,
const Slice& value, uint64_t expiration) { const Slice& value, uint64_t expiration) {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }
@ -157,7 +157,7 @@ class BlobDB : public StackableDB {
const std::vector<Slice>& keys, const std::vector<Slice>& keys,
std::vector<std::string>* values) override { std::vector<std::string>* values) override {
for (auto column_family : column_families) { for (auto column_family : column_families) {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return std::vector<Status>( return std::vector<Status>(
column_families.size(), column_families.size(),
Status::NotSupported( Status::NotSupported(
@ -197,7 +197,7 @@ class BlobDB : public StackableDB {
virtual Iterator* NewIterator(const ReadOptions& options) override = 0; virtual Iterator* NewIterator(const ReadOptions& options) override = 0;
virtual Iterator* NewIterator(const ReadOptions& options, virtual Iterator* NewIterator(const ReadOptions& options,
ColumnFamilyHandle* column_family) override { ColumnFamilyHandle* column_family) override {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
// Blob DB doesn't support non-default column family. // Blob DB doesn't support non-default column family.
return nullptr; return nullptr;
} }
@ -217,7 +217,7 @@ class BlobDB : public StackableDB {
const int output_path_id = -1, const int output_path_id = -1,
std::vector<std::string>* const output_file_names = nullptr, std::vector<std::string>* const output_file_names = nullptr,
CompactionJobInfo* compaction_job_info = nullptr) override { CompactionJobInfo* compaction_job_info = nullptr) override {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }

View File

@ -1466,7 +1466,7 @@ Status BlobDBImpl::Get(const ReadOptions& read_options,
Status BlobDBImpl::GetImpl(const ReadOptions& read_options, Status BlobDBImpl::GetImpl(const ReadOptions& read_options,
ColumnFamilyHandle* column_family, const Slice& key, ColumnFamilyHandle* column_family, const Slice& key,
PinnableSlice* value, uint64_t* expiration) { PinnableSlice* value, uint64_t* expiration) {
if (column_family != DefaultColumnFamily()) { if (column_family->GetID() != DefaultColumnFamily()->GetID()) {
return Status::NotSupported( return Status::NotSupported(
"Blob DB doesn't support non-default column family."); "Blob DB doesn't support non-default column family.");
} }