|
|
@ -3343,8 +3343,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (thread->shared->write_rate_limiter.get() != nullptr) { |
|
|
|
if (thread->shared->write_rate_limiter.get() != nullptr) { |
|
|
|
thread->shared->write_rate_limiter->Request( |
|
|
|
thread->shared->write_rate_limiter->Request( |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), Env::IO_HIGH, |
|
|
|
Env::IO_HIGH); |
|
|
|
nullptr /* stats */); |
|
|
|
// Set time at which last op finished to Now() to hide latency and
|
|
|
|
// Set time at which last op finished to Now() to hide latency and
|
|
|
|
// sleep from rate limiter. Also, do the check once per batch, not
|
|
|
|
// sleep from rate limiter. Also, do the check once per batch, not
|
|
|
|
// once per write.
|
|
|
|
// once per write.
|
|
|
@ -3704,7 +3704,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
i % 1024 == 1023) { |
|
|
|
i % 1024 == 1023) { |
|
|
|
thread->shared->read_rate_limiter->Request(1024, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(1024, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -3735,7 +3736,8 @@ class Benchmark { |
|
|
|
++i; |
|
|
|
++i; |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
i % 1024 == 1023) { |
|
|
|
i % 1024 == 1023) { |
|
|
|
thread->shared->read_rate_limiter->Request(1024, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(1024, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
delete iter; |
|
|
|
delete iter; |
|
|
@ -3776,7 +3778,8 @@ class Benchmark { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr) { |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr) { |
|
|
|
thread->shared->read_rate_limiter->Request(100, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(100, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
thread->stats.FinishedOps(nullptr, db, 100, kRead); |
|
|
|
thread->stats.FinishedOps(nullptr, db, 100, kRead); |
|
|
@ -3860,7 +3863,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
read % 256 == 255) { |
|
|
|
read % 256 == 255) { |
|
|
|
thread->shared->read_rate_limiter->Request(256, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(256, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
thread->stats.FinishedOps(db_with_cfh, db_with_cfh->db, 1, kRead); |
|
|
|
thread->stats.FinishedOps(db_with_cfh, db_with_cfh->db, 1, kRead); |
|
|
@ -3915,8 +3919,8 @@ class Benchmark { |
|
|
|
} |
|
|
|
} |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
num_multireads % 256 == 255) { |
|
|
|
num_multireads % 256 == 255) { |
|
|
|
thread->shared->read_rate_limiter->Request(256 * entries_per_batch_, |
|
|
|
thread->shared->read_rate_limiter->Request( |
|
|
|
Env::IO_HIGH); |
|
|
|
256 * entries_per_batch_, Env::IO_HIGH, nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
thread->stats.FinishedOps(nullptr, db, entries_per_batch_, kRead); |
|
|
|
thread->stats.FinishedOps(nullptr, db, entries_per_batch_, kRead); |
|
|
|
} |
|
|
|
} |
|
|
@ -4013,7 +4017,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr && |
|
|
|
read % 256 == 255) { |
|
|
|
read % 256 == 255) { |
|
|
|
thread->shared->read_rate_limiter->Request(256, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(256, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
thread->stats.FinishedOps(&db_, db_.db, 1, kSeek); |
|
|
|
thread->stats.FinishedOps(&db_, db_.db, 1, kSeek); |
|
|
@ -4143,8 +4148,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (FLAGS_benchmark_write_rate_limit > 0) { |
|
|
|
if (FLAGS_benchmark_write_rate_limit > 0) { |
|
|
|
write_rate_limiter->Request( |
|
|
|
write_rate_limiter->Request( |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), Env::IO_HIGH, |
|
|
|
Env::IO_HIGH); |
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
thread->stats.AddBytes(bytes); |
|
|
|
thread->stats.AddBytes(bytes); |
|
|
@ -4815,7 +4820,8 @@ class Benchmark { |
|
|
|
found += key_found; |
|
|
|
found += key_found; |
|
|
|
|
|
|
|
|
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr) { |
|
|
|
if (thread->shared->read_rate_limiter.get() != nullptr) { |
|
|
|
thread->shared->read_rate_limiter->Request(1, Env::IO_HIGH); |
|
|
|
thread->shared->read_rate_limiter->Request(1, Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
delete iter; |
|
|
|
delete iter; |
|
|
@ -4885,7 +4891,8 @@ class Benchmark { |
|
|
|
|
|
|
|
|
|
|
|
if (FLAGS_benchmark_write_rate_limit > 0) { |
|
|
|
if (FLAGS_benchmark_write_rate_limit > 0) { |
|
|
|
write_rate_limiter->Request( |
|
|
|
write_rate_limiter->Request( |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), Env::IO_HIGH); |
|
|
|
entries_per_batch_ * (value_size_ + key_size_), Env::IO_HIGH, |
|
|
|
|
|
|
|
nullptr /* stats */); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|