From 7a92537fc4fb5627b35f9118cca7fface3b733df Mon Sep 17 00:00:00 2001 From: Lei Jin Date: Thu, 10 Apr 2014 10:15:59 -0700 Subject: [PATCH] db_bench: add IteratorCreationWhileWriting mode and allow prefix_seek Summary: as title Test Plan: ran it Reviewers: igor, haobo, yhchiang Reviewed By: igor CC: leveldb Differential Revision: https://reviews.facebook.net/D17655 --- db/db_bench.cc | 102 +++++++++++++++++++++++++++++-------------------- 1 file changed, 60 insertions(+), 42 deletions(-) diff --git a/db/db_bench.cc b/db/db_bench.cc index 74af88b77eb..2cf8b70d53c 100644 --- a/db/db_bench.cc +++ b/db/db_bench.cc @@ -47,6 +47,8 @@ DEFINE_string(benchmarks, "overwrite," "readrandom," "readrandom," + "newiterator," + "newiteratorwhilewriting," "readseq," "readreverse," "compact," @@ -1172,6 +1174,9 @@ class Benchmark { method = &Benchmark::ReadRandom; } else if (name == Slice("newiterator")) { method = &Benchmark::IteratorCreation; + } else if (name == Slice("newiteratorwhilewriting")) { + num_threads++; // Add extra thread for writing + method = &Benchmark::IteratorCreationWhileWriting; } else if (name == Slice("seekrandom")) { method = &Benchmark::SeekRandom; } else if (name == Slice("readrandomsmall")) { @@ -1864,6 +1869,7 @@ class Benchmark { void IteratorCreation(ThreadState* thread) { Duration duration(FLAGS_duration, reads_); ReadOptions options(FLAGS_verify_checksum, true); + options.prefix_seek = (FLAGS_prefix_size > 0); while (!duration.Done(1)) { Iterator* iter = db_->NewIterator(options); delete iter; @@ -1871,6 +1877,14 @@ class Benchmark { } } + void IteratorCreationWhileWriting(ThreadState* thread) { + if (thread->tid > 0) { + IteratorCreation(thread); + } else { + BGWriter(thread); + } + } + void SeekRandom(ThreadState* thread) { int64_t read = 0; int64_t found = 0; @@ -1934,53 +1948,57 @@ class Benchmark { if (thread->tid > 0) { ReadRandom(thread); } else { - // Special thread that keeps writing until other threads are done. - RandomGenerator gen; - double last = FLAGS_env->NowMicros(); - int writes_per_second_by_10 = 0; - int num_writes = 0; - - // --writes_per_second rate limit is enforced per 100 milliseconds - // intervals to avoid a burst of writes at the start of each second. - - if (FLAGS_writes_per_second > 0) - writes_per_second_by_10 = FLAGS_writes_per_second / 10; - - // Don't merge stats from this thread with the readers. - thread->stats.SetExcludeFromMerge(); - - Slice key = AllocateKey(); - std::unique_ptr key_guard(key.data()); - - while (true) { - { - MutexLock l(&thread->shared->mu); - if (thread->shared->num_done + 1 >= thread->shared->num_initialized) { - // Other threads have finished - break; - } - } + BGWriter(thread); + } + } - GenerateKeyFromInt(thread->rand.Next() % FLAGS_num, FLAGS_num, &key); - Status s = db_->Put(write_options_, key, gen.Generate(value_size_)); - if (!s.ok()) { - fprintf(stderr, "put error: %s\n", s.ToString().c_str()); - exit(1); + void BGWriter(ThreadState* thread) { + // Special thread that keeps writing until other threads are done. + RandomGenerator gen; + double last = FLAGS_env->NowMicros(); + int writes_per_second_by_10 = 0; + int num_writes = 0; + + // --writes_per_second rate limit is enforced per 100 milliseconds + // intervals to avoid a burst of writes at the start of each second. + + if (FLAGS_writes_per_second > 0) + writes_per_second_by_10 = FLAGS_writes_per_second / 10; + + // Don't merge stats from this thread with the readers. + thread->stats.SetExcludeFromMerge(); + + Slice key = AllocateKey(); + std::unique_ptr key_guard(key.data()); + + while (true) { + { + MutexLock l(&thread->shared->mu); + if (thread->shared->num_done + 1 >= thread->shared->num_initialized) { + // Other threads have finished + break; } - thread->stats.FinishedSingleOp(db_); + } + + GenerateKeyFromInt(thread->rand.Next() % FLAGS_num, FLAGS_num, &key); + Status s = db_->Put(write_options_, key, gen.Generate(value_size_)); + if (!s.ok()) { + fprintf(stderr, "put error: %s\n", s.ToString().c_str()); + exit(1); + } + thread->stats.FinishedSingleOp(db_); - ++num_writes; - if (writes_per_second_by_10 && num_writes >= writes_per_second_by_10) { - double now = FLAGS_env->NowMicros(); - double usecs_since_last = now - last; + ++num_writes; + if (writes_per_second_by_10 && num_writes >= writes_per_second_by_10) { + double now = FLAGS_env->NowMicros(); + double usecs_since_last = now - last; - num_writes = 0; - last = now; + num_writes = 0; + last = now; - if (usecs_since_last < 100000.0) { - FLAGS_env->SleepForMicroseconds(100000.0 - usecs_since_last); - last = FLAGS_env->NowMicros(); - } + if (usecs_since_last < 100000.0) { + FLAGS_env->SleepForMicroseconds(100000.0 - usecs_since_last); + last = FLAGS_env->NowMicros(); } } }