Skip to content

Commit

Permalink
reduce lock's range in DeleteObsoleteFiles
Browse files Browse the repository at this point in the history
  • Loading branch information
司靖 authored and 司靖 committed Jun 20, 2016
1 parent 77948e7 commit 4f0425e
Showing 1 changed file with 12 additions and 3 deletions.
15 changes: 12 additions & 3 deletions db/db_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -216,32 +216,40 @@ void DBImpl::MaybeIgnoreError(Status* s) const {
}

void DBImpl::DeleteObsoleteFiles() {
mutex_.AssertHeld();

if (!bg_error_.ok()) {
// After a background error, we don't know whether a new version may
// or may not have been committed, so we cannot safely garbage collect.
return;
}

uint64_t log_number = versions_->LogNumber();
uint64_t prev_log_number = versions_->PrevLogNumber();
uint64_t manifest_file_number = versions_->ManifestFileNumber();

// Make a set of all of the live files
std::set<uint64_t> live = pending_outputs_;
versions_->AddLiveFiles(&live);

std::vector<std::string> filenames;
env_->GetChildren(dbname_, &filenames); // Ignoring errors on purpose

mutex_.Unlock();
uint64_t number;
FileType type;
for (size_t i = 0; i < filenames.size(); i++) {
if (ParseFileName(filenames[i], &number, &type)) {
bool keep = true;
switch (type) {
case kLogFile:
keep = ((number >= versions_->LogNumber()) ||
(number == versions_->PrevLogNumber()));
keep = ((number >= log_number) ||
(number == prev_log_number));
break;
case kDescriptorFile:
// Keep my manifest file, and any newer incarnations'
// (in case there is a race that allows other incarnations)
keep = (number >= versions_->ManifestFileNumber());
keep = (number >= manifest_file_number);
break;
case kTableFile:
keep = (live.find(number) != live.end());
Expand Down Expand Up @@ -269,6 +277,7 @@ void DBImpl::DeleteObsoleteFiles() {
}
}
}
mutex_.Lock();
}

Status DBImpl::Recover(VersionEdit* edit) {
Expand Down

0 comments on commit 4f0425e

Please sign in to comment.