Просмотр исходного кода

Merge pull request #386 from ivanabc:master

PiperOrigin-RevId: 250702492
xry
Chris Mumford 5 лет назад
Родитель
Сommit
4cb80b7ddc
1 измененных файлов: 10 добавлений и 3 удалений
  1. +10
    -3
      db/db_impl.cc

+ 10
- 3
db/db_impl.cc Просмотреть файл

@ -229,12 +229,19 @@ void DBImpl::DeleteObsoleteFiles() {
return;
}
const uint64_t log_number = versions_->LogNumber();
const uint64_t prev_log_number = versions_->PrevLogNumber();
const 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
// Unlock while deleting obsolete files
mutex_.Unlock();
uint64_t number;
FileType type;
for (size_t i = 0; i < filenames.size(); i++) {
@ -242,13 +249,12 @@ void DBImpl::DeleteObsoleteFiles() {
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());
@ -275,6 +281,7 @@ void DBImpl::DeleteObsoleteFiles() {
}
}
}
mutex_.Lock();
}
Status DBImpl::Recover(VersionEdit* edit, bool* save_manifest) {

Загрузка…
Отмена
Сохранить