Single threaded tests -> sync=0 Multi threaded tests -> sync=1 by default unless DB_BENCH_NO_SYNC is defined

Summary:
Single threaded tests -> sync=0 Multi threaded tests -> sync=1 by default unless DB_BENCH_NO_SYNC is defined.

Also added updaterandom and mergerandom with putOperator. I am waiting for some results from udb on this.

Test Plan:
DB_BENCH_NO_SYNC=1 WAL_DIR=/tmp OUTPUT_DIR=/tmp/b DB_DIR=/tmp ./tools/benchmark.sh debug,bulkload,fillseq,overwrite,filluniquerandom,readrandom,readwhilewriting,updaterandom,mergerandom

WAL_DIR=/tmp OUTPUT_DIR=/tmp/b DB_DIR=/tmp ./tools/benchmark.sh debug,bulkload,fillseq,overwrite,filluniquerandom,readrandom,readwhilewriting,updaterandom,mergerandom

Verify sync settings

Reviewers: sdong, MarkCallaghan, igor, rven

Reviewed By: igor, rven

Subscribers: dhruba

Differential Revision: https://reviews.facebook.net/D34185
This commit is contained in:
Leonidas Galanis 2015-03-06 14:12:53 -08:00
parent dc4532c497
commit e126e0da5b

View File

@ -2,7 +2,8 @@
# REQUIRE: db_bench binary exists in the current directory # REQUIRE: db_bench binary exists in the current directory
if [ $# -ne 1 ]; then if [ $# -ne 1 ]; then
echo "./benchmark.sh [bulkload/fillseq/overwrite/filluniquerandom/readrandom/readwhilewriting]" echo -n "./benchmark.sh [bulkload/fillseq/overwrite/filluniquerandom/"
echo "readrandom/readwhilewriting/updaterandom/mergerandom]"
exit 0 exit 0
fi fi
@ -26,6 +27,14 @@ if [ ! -d $output_dir ]; then
mkdir -p $output_dir mkdir -p $output_dir
fi fi
# all multithreaded tests run with sync=1 unless
# $DB_BENCH_NO_SYNC is defined
syncval="1"
if [ ! -z $DB_BENCH_NO_SYNC ]; then
echo "Turning sync off for all multithreaded tests"
syncval="0";
fi
num_read_threads=${NUM_READ_THREADS:-16} num_read_threads=${NUM_READ_THREADS:-16}
writes_per_second=${WRITES_PER_SEC:-$((80 * K))} # (only for readwhilewriting) writes_per_second=${WRITES_PER_SEC:-$((80 * K))} # (only for readwhilewriting)
num_nexts_per_seek=${NUM_NEXTS_PER_SEEK:-10} # (only for rangescanwhilewriting) num_nexts_per_seek=${NUM_NEXTS_PER_SEEK:-10} # (only for rangescanwhilewriting)
@ -94,7 +103,7 @@ function run_bulkload {
--disable_auto_compactions=1 \ --disable_auto_compactions=1 \
--sync=0 \ --sync=0 \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=1 2>&1 | tee $output_dir/benchmark_bulkload_fillrandom.log" --threads=1 2>&1 | tee -a $output_dir/benchmark_bulkload_fillrandom.log"
echo $cmd | tee $output_dir/benchmark_bulkload_fillrandom.log echo $cmd | tee $output_dir/benchmark_bulkload_fillrandom.log
eval $cmd eval $cmd
echo "Compacting..." echo "Compacting..."
@ -104,7 +113,7 @@ function run_bulkload {
--disable_auto_compactions=1 \ --disable_auto_compactions=1 \
--sync=0 \ --sync=0 \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=1 2>&1 | tee $output_dir/benchmark_bulkload_compact.log" --threads=1 2>&1 | tee -a $output_dir/benchmark_bulkload_compact.log"
echo $cmd | tee $output_dir/benchmark_bulkload_compact.log echo $cmd | tee $output_dir/benchmark_bulkload_compact.log
eval $cmd eval $cmd
} }
@ -114,9 +123,9 @@ function run_fillseq {
cmd="./db_bench $params_w --benchmarks=fillseq \ cmd="./db_bench $params_w --benchmarks=fillseq \
--use_existing_db=0 \ --use_existing_db=0 \
--num=$num_keys \ --num=$num_keys \
--sync=1 \ --sync=0 \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=1 2>&1 | tee $output_dir/benchmark_fillseq.log" --threads=1 2>&1 | tee -a $output_dir/benchmark_fillseq.log"
echo $cmd | tee $output_dir/benchmark_fillseq.log echo $cmd | tee $output_dir/benchmark_fillseq.log
eval $cmd eval $cmd
} }
@ -126,9 +135,9 @@ function run_overwrite {
cmd="./db_bench $params_w --benchmarks=overwrite \ cmd="./db_bench $params_w --benchmarks=overwrite \
--use_existing_db=1 \ --use_existing_db=1 \
--num=$num_keys \ --num=$num_keys \
--sync=1 \ --sync=0 \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=1 2>&1 | tee $output_dir/benchmark_overwrite.log" --threads=1 2>&1 | tee -a $output_dir/benchmark_overwrite.log"
echo $cmd | tee $output_dir/benchmark_overwrite.log echo $cmd | tee $output_dir/benchmark_overwrite.log
eval $cmd eval $cmd
} }
@ -138,9 +147,9 @@ function run_filluniquerandom {
cmd="./db_bench $params_w --benchmarks=filluniquerandom \ cmd="./db_bench $params_w --benchmarks=filluniquerandom \
--use_existing_db=0 \ --use_existing_db=0 \
--num=$num_keys \ --num=$num_keys \
--sync=1 \ --sync=0 \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=1 2>&1 | tee $output_dir/benchmark_filluniquerandom.log" --threads=1 2>&1 | tee -a $output_dir/benchmark_filluniquerandom.log"
echo $cmd | tee $output_dir/benchmark_filluniquerandom.log echo $cmd | tee $output_dir/benchmark_filluniquerandom.log
eval $cmd eval $cmd
} }
@ -152,7 +161,7 @@ function run_readrandom {
--num=$num_keys \ --num=$num_keys \
--threads=$num_read_threads \ --threads=$num_read_threads \
--disable_auto_compactions=1 \ --disable_auto_compactions=1 \
2>&1 | tee $output_dir/benchmark_readrandom.log" 2>&1 | tee -a $output_dir/benchmark_readrandom.log"
echo $cmd | tee $output_dir/benchmark_readrandom.log echo $cmd | tee $output_dir/benchmark_readrandom.log
eval $cmd eval $cmd
} }
@ -162,11 +171,11 @@ function run_readwhilewriting {
cmd="./db_bench $params_r --benchmarks=readwhilewriting \ cmd="./db_bench $params_r --benchmarks=readwhilewriting \
--use_existing_db=1 \ --use_existing_db=1 \
--num=$num_keys \ --num=$num_keys \
--sync=1 \ --sync=$syncval \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=$num_read_threads \ --threads=$num_read_threads \
--writes_per_second=$writes_per_second \ --writes_per_second=$writes_per_second \
2>&1 | tee $output_dir/benchmark_readwhilewriting.log" 2>&1 | tee -a $output_dir/benchmark_readwhilewriting.log"
echo $cmd | tee $output_dir/benchmark_readwhilewriting.log echo $cmd | tee $output_dir/benchmark_readwhilewriting.log
eval $cmd eval $cmd
} }
@ -176,16 +185,41 @@ function run_rangescanwhilewriting {
cmd="./db_bench $params_r --benchmarks=seekrandomwhilewriting \ cmd="./db_bench $params_r --benchmarks=seekrandomwhilewriting \
--use_existing_db=1 \ --use_existing_db=1 \
--num=$num_keys \ --num=$num_keys \
--sync=1 \ --sync=$syncval \
--disable_data_sync=0 \ --disable_data_sync=0 \
--threads=$num_read_threads \ --threads=$num_read_threads \
--writes_per_second=$writes_per_second \ --writes_per_second=$writes_per_second \
--seek_nexts=$num_nexts_per_seek \ --seek_nexts=$num_nexts_per_seek \
2>&1 | tee $output_dir/benchmark_rangescanwhilewriting.log" 2>&1 | tee -a $output_dir/benchmark_rangescanwhilewriting.log"
echo $cmd | tee $output_dir/benchmark_rangescanwhilewriting.log echo $cmd | tee $output_dir/benchmark_rangescanwhilewriting.log
eval $cmd eval $cmd
} }
function run_updaterandom {
echo "Read/Modify/Write $num_keys random keys (not using merge).."
cmd="./db_bench $params_w --benchmarks=updaterandom \
--use_existing_db=0 \
--num=$num_keys \
--sync=$syncval \
--disable_data_sync=0 \
--threads=$num_read_threads 2>&1 | tee -a $output_dir/benchmark_updaterandom.log"
echo $cmd | tee $output_dir/benchmark_updaterandom.log
eval $cmd
}
function run_mergerandom {
echo "Read/Modify/Write $num_keys random keys (using merge operator).."
cmd="./db_bench $params_w --benchmarks=mergerandom \
--use_existing_db=0 \
--num=$num_keys \
--sync=$syncval \
--disable_data_sync=0 \
--merge_operator=\"put\" \
--threads=$num_read_threads 2>&1 | tee -a $output_dir/benchmark_mergerandom.log"
echo $cmd | tee $output_dir/benchmark_mergerandom.log
eval $cmd
}
function now() { function now() {
echo `date +"%s"` echo `date +"%s"`
} }
@ -217,8 +251,12 @@ for job in ${jobs[@]}; do
run_readwhilewriting run_readwhilewriting
elif [ $job = rangescanwhilewriting ]; then elif [ $job = rangescanwhilewriting ]; then
run_rangescanwhilewriting run_rangescanwhilewriting
elif [ $job = updaterandom ]; then
run_updaterandom
elif [ $job = mergerandom ]; then
run_mergerandom
elif [ $job = debug ]; then elif [ $job = debug ]; then
num_keys=10000; # debug num_keys=1000; # debug
echo "Setting num_keys to $num_keys" echo "Setting num_keys to $num_keys"
else else
echo "unknown job $job" echo "unknown job $job"
@ -230,14 +268,18 @@ for job in ${jobs[@]}; do
echo "Complete $job in $((end-start)) seconds" | tee -a $report echo "Complete $job in $((end-start)) seconds" | tee -a $report
fi fi
if [[ $job = readrandom || $job = readwhilewriting || $job == rangescanwhilewriting ]]; then if [[ $job == readrandom || $job == readwhilewriting \
lat=$(grep "micros\/op" "$output_dir/benchmark_$job.log" | grep "ops\/sec" | awk '{print $3}') || $job == rangescanwhilewriting || $job == updaterandom \
qps=$(grep "micros\/op" "$output_dir/benchmark_$job.log" | grep "ops\/sec" | awk '{print $5}') || $job == mergerandom ]]; then
lat=$(grep "micros\/op" "$output_dir/benchmark_$job.log" \
| grep "ops\/sec" | awk '{print $3}')
qps=$(grep "micros\/op" "$output_dir/benchmark_$job.log" \
| grep "ops\/sec" | awk '{print $5}')
line=$(grep "rocksdb.db.get.micros" "$output_dir/benchmark_$job.log") line=$(grep "rocksdb.db.get.micros" "$output_dir/benchmark_$job.log")
p50=$(echo $line | awk '{print $7}') p50=$(echo $line | awk '{print $7}')
p99=$(echo $line | awk '{print $13}') p99=$(echo $line | awk '{print $13}')
print_percentile=$(echo "$p50 != 0 || $p99 != 0" | bc); print_percentile=$(echo "$p50 != 0 || $p99 != 0" | bc);
if [ $print_percentile == "1" ]; then if [ "$print_percentile" == "1" ]; then
echo "Read latency p50 = $p50 us, p99 = $p99 us" | tee -a $report echo "Read latency p50 = $p50 us, p99 = $p99 us" | tee -a $report
fi fi
echo "QPS = $qps ops/sec" | tee -a $report echo "QPS = $qps ops/sec" | tee -a $report