Fix data race in BlobStore benchmark

Summary: Apparently C++ doesn't like it if you copy around its atomic<> variables. When running a benchmark for a longer time, benchmark used to stall. Changed WorkerThread in config to WorkerThread*. It works now.

Test Plan: Ran benchmark

Reviewers: dhruba

Reviewed By: dhruba

CC: leveldb

Differential Revision: https://reviews.facebook.net/D13731
main
Igor Canadi 11 years ago
parent 994575c134
commit 17991cd5a0
  1. 36
      tools/blob_store_bench.cc

@ -125,16 +125,20 @@ static void WorkerThreadBody(void* arg) {
t->stopped.store(true); t->stopped.store(true);
} }
Result StartBenchmark(vector<WorkerThread>& config) { Result StartBenchmark(vector<WorkerThread*>& config) {
for (auto w : config) { for (auto w : config) {
env->StartThread(WorkerThreadBody, &w); env->StartThread(WorkerThreadBody, w);
} }
Result result; Result result;
for (auto w : config) { for (auto w : config) {
while (!w.stopped.load()); while (!w->stopped.load());
result = result + w.result; result = result + w->result;
}
for (auto w : config) {
delete w;
} }
delete bs; delete bs;
@ -142,7 +146,7 @@ Result StartBenchmark(vector<WorkerThread>& config) {
return result; return result;
} }
vector<WorkerThread> SetupBenchmarkBalanced() { vector<WorkerThread*> SetupBenchmarkBalanced() {
string test_path; string test_path;
env->GetTestDirectory(&test_path); env->GetTestDirectory(&test_path);
test_path.append("/blob_store"); test_path.append("/blob_store");
@ -160,10 +164,10 @@ vector<WorkerThread> SetupBenchmarkBalanced() {
bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env); bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env);
vector <WorkerThread> config; vector <WorkerThread*> config;
for (int i = 0; i < number_of_threads; ++i) { for (int i = 0; i < number_of_threads; ++i) {
config.push_back(WorkerThread(data_read_from, config.push_back(new WorkerThread(data_read_from,
data_read_to, data_read_to,
read_write_ratio, read_write_ratio,
working_set_size)); working_set_size));
@ -172,7 +176,7 @@ vector<WorkerThread> SetupBenchmarkBalanced() {
return config; return config;
} }
vector<WorkerThread> SetupBenchmarkWriteHeavy() { vector<WorkerThread*> SetupBenchmarkWriteHeavy() {
string test_path; string test_path;
env->GetTestDirectory(&test_path); env->GetTestDirectory(&test_path);
test_path.append("/blob_store"); test_path.append("/blob_store");
@ -190,10 +194,10 @@ vector<WorkerThread> SetupBenchmarkWriteHeavy() {
bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env); bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env);
vector <WorkerThread> config; vector <WorkerThread*> config;
for (int i = 0; i < number_of_threads; ++i) { for (int i = 0; i < number_of_threads; ++i) {
config.push_back(WorkerThread(data_read_from, config.push_back(new WorkerThread(data_read_from,
data_read_to, data_read_to,
read_write_ratio, read_write_ratio,
working_set_size)); working_set_size));
@ -202,7 +206,7 @@ vector<WorkerThread> SetupBenchmarkWriteHeavy() {
return config; return config;
} }
vector<WorkerThread> SetupBenchmarkReadHeavy() { vector<WorkerThread*> SetupBenchmarkReadHeavy() {
string test_path; string test_path;
env->GetTestDirectory(&test_path); env->GetTestDirectory(&test_path);
test_path.append("/blob_store"); test_path.append("/blob_store");
@ -220,10 +224,10 @@ vector<WorkerThread> SetupBenchmarkReadHeavy() {
bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env); bs = new BlobStore(test_path, block_size, file_size / block_size, 10000, env);
vector <WorkerThread> config; vector <WorkerThread*> config;
for (int i = 0; i < number_of_threads; ++i) { for (int i = 0; i < number_of_threads; ++i) {
config.push_back(WorkerThread(data_read_from, config.push_back(new WorkerThread(data_read_from,
data_read_to, data_read_to,
read_write_ratio, read_write_ratio,
working_set_size)); working_set_size));
@ -238,19 +242,19 @@ int main(int argc, const char** argv) {
{ {
printf("--- Balanced read/write benchmark ---\n"); printf("--- Balanced read/write benchmark ---\n");
vector <WorkerThread> config = SetupBenchmarkBalanced(); vector <WorkerThread*> config = SetupBenchmarkBalanced();
Result r = StartBenchmark(config); Result r = StartBenchmark(config);
r.print(); r.print();
} }
{ {
printf("--- Write heavy benchmark ---\n"); printf("--- Write heavy benchmark ---\n");
vector <WorkerThread> config = SetupBenchmarkWriteHeavy(); vector <WorkerThread*> config = SetupBenchmarkWriteHeavy();
Result r = StartBenchmark(config); Result r = StartBenchmark(config);
r.print(); r.print();
} }
{ {
printf("--- Read heavy benchmark ---\n"); printf("--- Read heavy benchmark ---\n");
vector <WorkerThread> config = SetupBenchmarkReadHeavy(); vector <WorkerThread*> config = SetupBenchmarkReadHeavy();
Result r = StartBenchmark(config); Result r = StartBenchmark(config);
r.print(); r.print();
} }

Loading…
Cancel
Save