|
|
@ -99,9 +99,7 @@ struct SstFileWriter::Rep { |
|
|
|
file_info.largest_key.assign(user_key.data(), user_key.size()); |
|
|
|
file_info.largest_key.assign(user_key.data(), user_key.size()); |
|
|
|
file_info.file_size = builder->FileSize(); |
|
|
|
file_info.file_size = builder->FileSize(); |
|
|
|
|
|
|
|
|
|
|
|
InvalidatePageCache(false /* closing */); |
|
|
|
return InvalidatePageCache(false /* closing */); |
|
|
|
|
|
|
|
|
|
|
|
return Status::OK(); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Status DeleteRange(const Slice& begin_key, const Slice& end_key) { |
|
|
|
Status DeleteRange(const Slice& begin_key, const Slice& end_key) { |
|
|
@ -135,15 +133,14 @@ struct SstFileWriter::Rep { |
|
|
|
file_info.num_range_del_entries++; |
|
|
|
file_info.num_range_del_entries++; |
|
|
|
file_info.file_size = builder->FileSize(); |
|
|
|
file_info.file_size = builder->FileSize(); |
|
|
|
|
|
|
|
|
|
|
|
InvalidatePageCache(false /* closing */); |
|
|
|
return InvalidatePageCache(false /* closing */); |
|
|
|
|
|
|
|
|
|
|
|
return Status::OK(); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void InvalidatePageCache(bool closing) { |
|
|
|
Status InvalidatePageCache(bool closing) { |
|
|
|
|
|
|
|
Status s = Status::OK(); |
|
|
|
if (invalidate_page_cache == false) { |
|
|
|
if (invalidate_page_cache == false) { |
|
|
|
// Fadvise disabled
|
|
|
|
// Fadvise disabled
|
|
|
|
return; |
|
|
|
return s; |
|
|
|
} |
|
|
|
} |
|
|
|
uint64_t bytes_since_last_fadvise = |
|
|
|
uint64_t bytes_since_last_fadvise = |
|
|
|
builder->FileSize() - last_fadvise_size; |
|
|
|
builder->FileSize() - last_fadvise_size; |
|
|
@ -151,11 +148,16 @@ struct SstFileWriter::Rep { |
|
|
|
TEST_SYNC_POINT_CALLBACK("SstFileWriter::Rep::InvalidatePageCache", |
|
|
|
TEST_SYNC_POINT_CALLBACK("SstFileWriter::Rep::InvalidatePageCache", |
|
|
|
&(bytes_since_last_fadvise)); |
|
|
|
&(bytes_since_last_fadvise)); |
|
|
|
// Tell the OS that we don't need this file in page cache
|
|
|
|
// Tell the OS that we don't need this file in page cache
|
|
|
|
file_writer->InvalidateCache(0, 0); |
|
|
|
s = file_writer->InvalidateCache(0, 0); |
|
|
|
|
|
|
|
if (s.IsNotSupported()) { |
|
|
|
|
|
|
|
// NotSupported is fine as it could be a file type that doesn't use page
|
|
|
|
|
|
|
|
// cache.
|
|
|
|
|
|
|
|
s = Status::OK(); |
|
|
|
|
|
|
|
} |
|
|
|
last_fadvise_size = builder->FileSize(); |
|
|
|
last_fadvise_size = builder->FileSize(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return s; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
SstFileWriter::SstFileWriter(const EnvOptions& env_options, |
|
|
|
SstFileWriter::SstFileWriter(const EnvOptions& env_options, |
|
|
@ -306,7 +308,9 @@ Status SstFileWriter::Finish(ExternalSstFileInfo* file_info) { |
|
|
|
|
|
|
|
|
|
|
|
if (s.ok()) { |
|
|
|
if (s.ok()) { |
|
|
|
s = r->file_writer->Sync(r->ioptions.use_fsync); |
|
|
|
s = r->file_writer->Sync(r->ioptions.use_fsync); |
|
|
|
r->InvalidatePageCache(true /* closing */); |
|
|
|
if (s.ok()) { |
|
|
|
|
|
|
|
s = r->InvalidatePageCache(true /* closing */); |
|
|
|
|
|
|
|
} |
|
|
|
if (s.ok()) { |
|
|
|
if (s.ok()) { |
|
|
|
s = r->file_writer->Close(); |
|
|
|
s = r->file_writer->Close(); |
|
|
|
} |
|
|
|
} |
|
|
|