Merge branch 'io_priority_write_1' of github.com:gitbw95/rocksdb into io_priority_write_1

This commit is contained in:
bowang 2022-05-12 16:39:29 -07:00
commit edec6d767b
2 changed files with 19 additions and 0 deletions

View File

@ -1074,7 +1074,12 @@ Env::IOPriority FlushJob::GetRateLimiterPriority(
versions_->GetColumnFamilySet()->write_controller(); versions_->GetColumnFamilySet()->write_controller();
if (op_type == RateLimiter::OpType::kWrite) { if (op_type == RateLimiter::OpType::kWrite) {
<<<<<<< HEAD
if (write_controller->IsStopped() || write_controller->NeedsDelay()) { if (write_controller->IsStopped() || write_controller->NeedsDelay()) {
=======
if (UNLIKELY(write_controller->IsStopped()) ||
UNLIKELY(write_controller->NeedsDelay())) {
>>>>>>> c19ac641ea67dd068be5e50e86de84f26f396e65
return Env::IO_USER; return Env::IO_USER;
} }
return Env::IO_HIGH; return Env::IO_HIGH;

View File

@ -54,12 +54,20 @@ IOStatus WritableFileWriter::Append(const Slice& data, uint32_t crc32c_checksum,
UpdateFileChecksum(data); UpdateFileChecksum(data);
{ {
<<<<<<< HEAD
IOOptions io_options; IOOptions io_options;
=======
std::unique_ptr<IOOptions> io_options;
>>>>>>> c19ac641ea67dd068be5e50e86de84f26f396e65
UpdateIOOptionsIfNeeded(io_options, op_rate_limiter_priority); UpdateIOOptionsIfNeeded(io_options, op_rate_limiter_priority);
IOSTATS_TIMER_GUARD(prepare_write_nanos); IOSTATS_TIMER_GUARD(prepare_write_nanos);
TEST_SYNC_POINT("WritableFileWriter::Append:BeforePrepareWrite"); TEST_SYNC_POINT("WritableFileWriter::Append:BeforePrepareWrite");
writable_file_->PrepareWrite(static_cast<size_t>(GetFileSize()), left, writable_file_->PrepareWrite(static_cast<size_t>(GetFileSize()), left,
<<<<<<< HEAD
io_options, nullptr); io_options, nullptr);
=======
*io_options, nullptr);
>>>>>>> c19ac641ea67dd068be5e50e86de84f26f396e65
} }
// See whether we need to enlarge the buffer to avoid the flush // See whether we need to enlarge the buffer to avoid the flush
@ -335,9 +343,15 @@ IOStatus WritableFileWriter::Flush(Env::IOPriority op_rate_limiter_priority) {
start_ts = FileOperationInfo::StartNow(); start_ts = FileOperationInfo::StartNow();
} }
#endif #endif
<<<<<<< HEAD
IOOptions io_options; IOOptions io_options;
UpdateIOOptionsIfNeeded(io_options, op_rate_limiter_priority); UpdateIOOptionsIfNeeded(io_options, op_rate_limiter_priority);
s = writable_file_->Flush(io_options, nullptr); s = writable_file_->Flush(io_options, nullptr);
=======
std::unique_ptr<IOOptions> io_options;
UpdateIOOptionsIfNeeded(io_options, op_rate_limiter_priority);
s = writable_file_->Flush(*io_options, nullptr);
>>>>>>> c19ac641ea67dd068be5e50e86de84f26f396e65
#ifndef ROCKSDB_LITE #ifndef ROCKSDB_LITE
if (ShouldNotifyListeners()) { if (ShouldNotifyListeners()) {
auto finish_ts = std::chrono::steady_clock::now(); auto finish_ts = std::chrono::steady_clock::now();