Ability to make the benchmark issue a large number of IOs. This is helpful to populate many gigabytes of data for benchmarking at scale.

Summary:
Task ID: #

Blame Rev:

Test Plan: Revert Plan:

Differential Revision: https://reviews.facebook.net/D3333
main
Dhruba Borthakur 13 years ago
parent 3b86a51cb1
commit 33a3c6ff6c
  1. 37
      db/db_bench.cc

@ -61,10 +61,10 @@ static const char* FLAGS_benchmarks =
; ;
// Number of key/values to place in database // Number of key/values to place in database
static int FLAGS_num = 1000000; static long FLAGS_num = 1000000;
// Number of read operations to do. If negative, do FLAGS_num reads. // Number of read operations to do. If negative, do FLAGS_num reads.
static int FLAGS_reads = -1; static long FLAGS_reads = -1;
// Number of concurrent threads to run. // Number of concurrent threads to run.
static int FLAGS_threads = 1; static int FLAGS_threads = 1;
@ -171,7 +171,7 @@ class Stats {
double start_; double start_;
double finish_; double finish_;
double seconds_; double seconds_;
int done_; long done_;
int next_report_; int next_report_;
int64_t bytes_; int64_t bytes_;
double last_op_finish_; double last_op_finish_;
@ -235,7 +235,7 @@ class Stats {
else if (next_report_ < 100000) next_report_ += 10000; else if (next_report_ < 100000) next_report_ += 10000;
else if (next_report_ < 500000) next_report_ += 50000; else if (next_report_ < 500000) next_report_ += 50000;
else next_report_ += 100000; else next_report_ += 100000;
fprintf(stderr, "... finished %d ops%30s\r", done_, ""); fprintf(stderr, "... finished %ld ops%30s\r", done_, "");
fflush(stderr); fflush(stderr);
} }
} }
@ -288,8 +288,8 @@ struct SharedState {
// (3) running // (3) running
// (4) done // (4) done
int num_initialized; long num_initialized;
int num_done; long num_done;
bool start; bool start;
SharedState() : cv(&mu) { } SharedState() : cv(&mu) { }
@ -315,11 +315,11 @@ class Benchmark {
Cache* cache_; Cache* cache_;
const FilterPolicy* filter_policy_; const FilterPolicy* filter_policy_;
DB* db_; DB* db_;
int num_; long num_;
int value_size_; int value_size_;
int entries_per_batch_; int entries_per_batch_;
WriteOptions write_options_; WriteOptions write_options_;
int reads_; long reads_;
int heap_counter_; int heap_counter_;
void PrintHeader() { void PrintHeader() {
@ -329,7 +329,7 @@ class Benchmark {
fprintf(stdout, "Values: %d bytes each (%d bytes after compression)\n", fprintf(stdout, "Values: %d bytes each (%d bytes after compression)\n",
FLAGS_value_size, FLAGS_value_size,
static_cast<int>(FLAGS_value_size * FLAGS_compression_ratio + 0.5)); static_cast<int>(FLAGS_value_size * FLAGS_compression_ratio + 0.5));
fprintf(stdout, "Entries: %d\n", num_); fprintf(stdout, "Entries: %ld\n", num_);
fprintf(stdout, "RawSize: %.1f MB (estimated)\n", fprintf(stdout, "RawSize: %.1f MB (estimated)\n",
((static_cast<int64_t>(kKeySize + FLAGS_value_size) * num_) ((static_cast<int64_t>(kKeySize + FLAGS_value_size) * num_)
/ 1048576.0)); / 1048576.0));
@ -755,7 +755,7 @@ class Benchmark {
void ReadSequential(ThreadState* thread) { void ReadSequential(ThreadState* thread) {
Iterator* iter = db_->NewIterator(ReadOptions(FLAGS_verify_checksum, true)); Iterator* iter = db_->NewIterator(ReadOptions(FLAGS_verify_checksum, true));
int i = 0; long i = 0;
int64_t bytes = 0; int64_t bytes = 0;
for (iter->SeekToFirst(); i < reads_ && iter->Valid(); iter->Next()) { for (iter->SeekToFirst(); i < reads_ && iter->Valid(); iter->Next()) {
bytes += iter->key().size() + iter->value().size(); bytes += iter->key().size() + iter->value().size();
@ -768,7 +768,7 @@ class Benchmark {
void ReadReverse(ThreadState* thread) { void ReadReverse(ThreadState* thread) {
Iterator* iter = db_->NewIterator(ReadOptions(FLAGS_verify_checksum, true)); Iterator* iter = db_->NewIterator(ReadOptions(FLAGS_verify_checksum, true));
int i = 0; long i = 0;
int64_t bytes = 0; int64_t bytes = 0;
for (iter->SeekToLast(); i < reads_ && iter->Valid(); iter->Prev()) { for (iter->SeekToLast(); i < reads_ && iter->Valid(); iter->Prev()) {
bytes += iter->key().size() + iter->value().size(); bytes += iter->key().size() + iter->value().size();
@ -783,7 +783,7 @@ class Benchmark {
ReadOptions options(FLAGS_verify_checksum, true); ReadOptions options(FLAGS_verify_checksum, true);
std::string value; std::string value;
int found = 0; int found = 0;
for (int i = 0; i < reads_; i++) { for (long i = 0; i < reads_; i++) {
char key[100]; char key[100];
const int k = thread->rand.Next() % FLAGS_num; const int k = thread->rand.Next() % FLAGS_num;
snprintf(key, sizeof(key), "%016d", k); snprintf(key, sizeof(key), "%016d", k);
@ -800,7 +800,7 @@ class Benchmark {
void ReadMissing(ThreadState* thread) { void ReadMissing(ThreadState* thread) {
ReadOptions options(FLAGS_verify_checksum, true); ReadOptions options(FLAGS_verify_checksum, true);
std::string value; std::string value;
for (int i = 0; i < reads_; i++) { for (long i = 0; i < reads_; i++) {
char key[100]; char key[100];
const int k = thread->rand.Next() % FLAGS_num; const int k = thread->rand.Next() % FLAGS_num;
snprintf(key, sizeof(key), "%016d.", k); snprintf(key, sizeof(key), "%016d.", k);
@ -812,8 +812,8 @@ class Benchmark {
void ReadHot(ThreadState* thread) { void ReadHot(ThreadState* thread) {
ReadOptions options(FLAGS_verify_checksum, true); ReadOptions options(FLAGS_verify_checksum, true);
std::string value; std::string value;
const int range = (FLAGS_num + 99) / 100; const long range = (FLAGS_num + 99) / 100;
for (int i = 0; i < reads_; i++) { for (long i = 0; i < reads_; i++) {
char key[100]; char key[100];
const int k = thread->rand.Next() % range; const int k = thread->rand.Next() % range;
snprintf(key, sizeof(key), "%016d", k); snprintf(key, sizeof(key), "%016d", k);
@ -826,7 +826,7 @@ class Benchmark {
ReadOptions options(FLAGS_verify_checksum, true); ReadOptions options(FLAGS_verify_checksum, true);
std::string value; std::string value;
int found = 0; int found = 0;
for (int i = 0; i < reads_; i++) { for (long i = 0; i < reads_; i++) {
Iterator* iter = db_->NewIterator(options); Iterator* iter = db_->NewIterator(options);
char key[100]; char key[100];
const int k = thread->rand.Next() % FLAGS_num; const int k = thread->rand.Next() % FLAGS_num;
@ -943,6 +943,7 @@ int main(int argc, char** argv) {
for (int i = 1; i < argc; i++) { for (int i = 1; i < argc; i++) {
double d; double d;
int n; int n;
long l;
char junk; char junk;
if (leveldb::Slice(argv[i]).starts_with("--benchmarks=")) { if (leveldb::Slice(argv[i]).starts_with("--benchmarks=")) {
FLAGS_benchmarks = argv[i] + strlen("--benchmarks="); FLAGS_benchmarks = argv[i] + strlen("--benchmarks=");
@ -954,8 +955,8 @@ int main(int argc, char** argv) {
} else if (sscanf(argv[i], "--use_existing_db=%d%c", &n, &junk) == 1 && } else if (sscanf(argv[i], "--use_existing_db=%d%c", &n, &junk) == 1 &&
(n == 0 || n == 1)) { (n == 0 || n == 1)) {
FLAGS_use_existing_db = n; FLAGS_use_existing_db = n;
} else if (sscanf(argv[i], "--num=%d%c", &n, &junk) == 1) { } else if (sscanf(argv[i], "--num=%ld%c", &l, &junk) == 1) {
FLAGS_num = n; FLAGS_num = l;
} else if (sscanf(argv[i], "--reads=%d%c", &n, &junk) == 1) { } else if (sscanf(argv[i], "--reads=%d%c", &n, &junk) == 1) {
FLAGS_reads = n; FLAGS_reads = n;
} else if (sscanf(argv[i], "--threads=%d%c", &n, &junk) == 1) { } else if (sscanf(argv[i], "--threads=%d%c", &n, &junk) == 1) {

Loading…
Cancel
Save