Skip to content

Commit

Permalink
dynamic delay: fix pending bytes rate calculation
Browse files Browse the repository at this point in the history
use fixed num delay steps instead of fixing the step size and deducing
the num steps.
this makes the code simpler and avoids a bug when the excess bytes are
greater than num_steps * step_size which then fails the assert:
assert(step_num < num_steps);  - since step_num == num_steps.
  • Loading branch information
Yuval-Ariel committed Mar 26, 2023
1 parent 19d5597 commit 3e68c7e
Showing 1 changed file with 9 additions and 10 deletions.
19 changes: 9 additions & 10 deletions db/column_family.cc
Original file line number Diff line number Diff line change
Expand Up @@ -899,6 +899,7 @@ namespace {
const uint64_t Gb = 1ull << 30;
const uint64_t Mb = 1ull << 20;
const int kMemtablePenalty = 10;
const int kNumPendingSteps = 100;
} // namespace

double ColumnFamilyData::TEST_CalculateWriteDelayDivider(
Expand Down Expand Up @@ -1001,21 +1002,19 @@ ColumnFamilyData::CalculateWriteDelayDividerAndMaybeUpdateWriteStallCause(
// Pending Compaction Bytes
double pending_divider = 1;
auto soft_limit = mutable_cf_options.soft_pending_compaction_bytes_limit;
if (soft_limit > 0 && compaction_needed_bytes >= soft_limit) {
if (soft_limit > 0 && compaction_needed_bytes > soft_limit) {
auto hard_limit = mutable_cf_options.hard_pending_compaction_bytes_limit;
// soft_limit != hard_limit here. we're in a kDelayed state here and not
// stop.
assert(hard_limit > soft_limit);
uint64_t soft_hard_range = hard_limit - soft_limit;
// change rate every 1G change or 100Mb if soft_hard_range is too small.
auto step_size = soft_hard_range > Gb ? Gb : 100 * Mb;
uint64_t num_steps = soft_hard_range / step_size;
auto extra_bytes = compaction_needed_bytes - soft_limit;
auto step_num = static_cast<uint64_t>(extra_bytes / step_size);
assert(step_num < num_steps);
if (num_steps > 0) {
pending_divider = 1 / (1 - (static_cast<double>(step_num) / num_steps));
}
uint64_t step_size = ceil(soft_hard_range / kNumPendingSteps);
uint64_t extra_bytes = compaction_needed_bytes - soft_limit;
assert(extra_bytes > 0);
uint64_t step_num = extra_bytes / step_size;
assert(step_num < kNumPendingSteps);
pending_divider =
1 / (1 - (static_cast<double>(step_num) / kNumPendingSteps));
}

double biggest_divider = 1;
Expand Down

0 comments on commit 3e68c7e

Please sign in to comment.