Abstract out SetMaxPossibleForUserKey() and SetMinPossibleForUserKey

Summary:
Based on feedback from D37083.

Are all of these correct? In some spaces it seems like we're doing SetMaxPossibleForUserKey() although we want the smallest possible internal key for user key.

Test Plan: make check

Reviewers: sdong

Reviewed By: sdong

Subscribers: dhruba, leveldb

Differential Revision: https://reviews.facebook.net/D37341
main
Igor Canadi 10 years ago
parent fd7a357318
commit e003d3864c
  1. 9
      db/db_impl.cc
  2. 4
      db/db_impl_experimental.cc
  3. 14
      db/dbformat.h
  4. 6
      db/version_set.cc
  5. 3
      util/ldb_cmd.cc
  6. 3
      util/sst_dump_tool.cc

@ -1686,7 +1686,7 @@ Status DBImpl::RunManualCompaction(ColumnFamilyData* cfd, int input_level,
cfd->ioptions()->compaction_style == kCompactionStyleFIFO) { cfd->ioptions()->compaction_style == kCompactionStyleFIFO) {
manual.begin = nullptr; manual.begin = nullptr;
} else { } else {
begin_storage = InternalKey(*begin, kMaxSequenceNumber, kValueTypeForSeek); begin_storage.SetMaxPossibleForUserKey(*begin);
manual.begin = &begin_storage; manual.begin = &begin_storage;
} }
if (end == nullptr || if (end == nullptr ||
@ -1694,7 +1694,7 @@ Status DBImpl::RunManualCompaction(ColumnFamilyData* cfd, int input_level,
cfd->ioptions()->compaction_style == kCompactionStyleFIFO) { cfd->ioptions()->compaction_style == kCompactionStyleFIFO) {
manual.end = nullptr; manual.end = nullptr;
} else { } else {
end_storage = InternalKey(*end, 0, static_cast<ValueType>(0)); end_storage.SetMinPossibleForUserKey(*end);
manual.end = &end_storage; manual.end = &end_storage;
} }
@ -3555,8 +3555,9 @@ void DBImpl::GetApproximateSizes(ColumnFamilyHandle* column_family,
for (int i = 0; i < n; i++) { for (int i = 0; i < n; i++) {
// Convert user_key into a corresponding internal key. // Convert user_key into a corresponding internal key.
InternalKey k1(range[i].start, kMaxSequenceNumber, kValueTypeForSeek); InternalKey k1, k2;
InternalKey k2(range[i].limit, kMaxSequenceNumber, kValueTypeForSeek); k1.SetMaxPossibleForUserKey(range[i].start);
k2.SetMaxPossibleForUserKey(range[i].limit);
uint64_t start = versions_->ApproximateOffsetOf(v, k1); uint64_t start = versions_->ApproximateOffsetOf(v, k1);
uint64_t limit = versions_->ApproximateOffsetOf(v, k2); uint64_t limit = versions_->ApproximateOffsetOf(v, k2);
sizes[i] = (limit >= start ? limit - start : 0); sizes[i] = (limit >= start ? limit - start : 0);

@ -30,10 +30,10 @@ Status DBImpl::SuggestCompactRange(ColumnFamilyHandle* column_family,
auto cfd = cfh->cfd(); auto cfd = cfh->cfd();
InternalKey start_key, end_key; InternalKey start_key, end_key;
if (begin != nullptr) { if (begin != nullptr) {
start_key = InternalKey(*begin, kMaxSequenceNumber, kValueTypeForSeek); start_key.SetMaxPossibleForUserKey(*begin);
} }
if (end != nullptr) { if (end != nullptr) {
end_key = InternalKey(*end, 0, static_cast<ValueType>(0)); end_key.SetMinPossibleForUserKey(*end);
} }
{ {
InstrumentedMutexLock l(&mutex_); InstrumentedMutexLock l(&mutex_);

@ -135,6 +135,20 @@ class InternalKey {
AppendInternalKey(&rep_, ParsedInternalKey(_user_key, s, t)); AppendInternalKey(&rep_, ParsedInternalKey(_user_key, s, t));
} }
// sets the internal key to be bigger or equal to all internal keys with this
// user key
void SetMaxPossibleForUserKey(const Slice& _user_key) {
AppendInternalKey(&rep_, ParsedInternalKey(_user_key, kMaxSequenceNumber,
kValueTypeForSeek));
}
// sets the internal key to be smaller or equal to all internal keys with this
// user key
void SetMinPossibleForUserKey(const Slice& _user_key) {
AppendInternalKey(
&rep_, ParsedInternalKey(_user_key, 0, static_cast<ValueType>(0)));
}
bool Valid() const { bool Valid() const {
ParsedInternalKey parsed; ParsedInternalKey parsed;
return ParseInternalKey(Slice(rep_), &parsed); return ParseInternalKey(Slice(rep_), &parsed);

@ -397,7 +397,8 @@ bool SomeFileOverlapsRange(
uint32_t index = 0; uint32_t index = 0;
if (smallest_user_key != nullptr) { if (smallest_user_key != nullptr) {
// Find the earliest possible internal key for smallest_user_key // Find the earliest possible internal key for smallest_user_key
InternalKey small(*smallest_user_key, kMaxSequenceNumber,kValueTypeForSeek); InternalKey small;
small.SetMaxPossibleForUserKey(*smallest_user_key);
index = FindFile(icmp, file_level, small.Encode()); index = FindFile(icmp, file_level, small.Encode());
} }
@ -1230,7 +1231,8 @@ int VersionStorageInfo::PickLevelForMemTableOutput(
if (!OverlapInLevel(0, &smallest_user_key, &largest_user_key)) { if (!OverlapInLevel(0, &smallest_user_key, &largest_user_key)) {
// Push to next level if there is no overlap in next level, // Push to next level if there is no overlap in next level,
// and the #bytes overlapping in the level after that are limited. // and the #bytes overlapping in the level after that are limited.
InternalKey start(smallest_user_key, kMaxSequenceNumber, kValueTypeForSeek); InternalKey start;
start.SetMaxPossibleForUserKey(smallest_user_key);
InternalKey limit(largest_user_key, 0, static_cast<ValueType>(0)); InternalKey limit(largest_user_key, 0, static_cast<ValueType>(0));
std::vector<FileMetaData*> overlaps; std::vector<FileMetaData*> overlaps;
while (mutable_cf_options.max_mem_compaction_level > 0 && while (mutable_cf_options.max_mem_compaction_level > 0 &&

@ -796,7 +796,8 @@ void InternalDumpCommand::DoCommand() {
} }
if (has_from_) { if (has_from_) {
InternalKey ikey(from_, kMaxSequenceNumber, kValueTypeForSeek); InternalKey ikey;
ikey.SetMaxPossibleForUserKey(from_);
iter->Seek(ikey.Encode()); iter->Seek(ikey.Encode());
} else { } else {
iter->SeekToFirst(); iter->SeekToFirst();

@ -187,7 +187,8 @@ Status SstFileReader::ReadSequential(bool print_kv,
false)); false));
uint64_t i = 0; uint64_t i = 0;
if (has_from) { if (has_from) {
InternalKey ikey(from_key, kMaxSequenceNumber, kValueTypeForSeek); InternalKey ikey;
ikey.SetMaxPossibleForUserKey(from_key);
iter->Seek(ikey.Encode()); iter->Seek(ikey.Encode());
} else { } else {
iter->SeekToFirst(); iter->SeekToFirst();

Loading…
Cancel
Save