fixup commit

Summary: I accidentally left out these changes from my commit of D64053 due to
messing up the merge conflict resolution.

Test Plan: ./db_wal_test

Reviewers:

Subscribers:

Tasks:

Blame Revision: D64053
main
Andrew Kryczka 8 years ago
parent 1b7af5fb1a
commit 017de666c7
  1. 8
      db/db_impl.cc
  2. 4
      db/job_context.h

@ -900,6 +900,8 @@ void DBImpl::FindObsoleteFiles(JobContext* job_context, bool force,
// We're just cleaning up for DB::Write(). // We're just cleaning up for DB::Write().
assert(job_context->logs_to_free.empty()); assert(job_context->logs_to_free.empty());
job_context->logs_to_free = logs_to_free_; job_context->logs_to_free = logs_to_free_;
job_context->log_recycle_files.assign(log_recycle_files.begin(),
log_recycle_files.end());
logs_to_free_.clear(); logs_to_free_.clear();
} }
@ -969,6 +971,8 @@ void DBImpl::PurgeObsoleteFiles(const JobContext& state, bool schedule_only) {
for (const FileDescriptor& fd : state.sst_live) { for (const FileDescriptor& fd : state.sst_live) {
sst_live_map[fd.GetNumber()] = &fd; sst_live_map[fd.GetNumber()] = &fd;
} }
std::unordered_set<uint64_t> log_recycle_files_set(
state.log_recycle_files.begin(), state.log_recycle_files.end());
auto candidate_files = state.full_scan_candidate_files; auto candidate_files = state.full_scan_candidate_files;
candidate_files.reserve( candidate_files.reserve(
@ -1027,7 +1031,9 @@ void DBImpl::PurgeObsoleteFiles(const JobContext& state, bool schedule_only) {
switch (type) { switch (type) {
case kLogFile: case kLogFile:
keep = ((number >= state.log_number) || keep = ((number >= state.log_number) ||
(number == state.prev_log_number)); (number == state.prev_log_number) ||
(log_recycle_files_set.find(number) !=
log_recycle_files_set.end()));
break; break;
case kDescriptorFile: case kDescriptorFile:
// Keep my manifest file, and any newer incarnations' // Keep my manifest file, and any newer incarnations'

@ -55,6 +55,10 @@ struct JobContext {
// a list of log files that we need to delete // a list of log files that we need to delete
std::vector<uint64_t> log_delete_files; std::vector<uint64_t> log_delete_files;
// a list of log files that we need to preserve during full purge since they
// will be reused later
std::vector<uint64_t> log_recycle_files;
// a list of manifest files that we need to delete // a list of manifest files that we need to delete
std::vector<std::string> manifest_delete_files; std::vector<std::string> manifest_delete_files;

Loading…
Cancel
Save