| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | #!/usr/bin/env bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 21:21:32 +00:00
										 |  |  | set -ex | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step() { | 
					
						
							|  |  |  | 	if [ -z "$1" ]; then | 
					
						
							|  |  |  | 		echo run_step called with no parameter | 
					
						
							|  |  |  | 		exit 1 | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	echo "--spdk=$ROCKSDB_CONF" >> "$1"_flags.txt | 
					
						
							|  |  |  | 	echo "--spdk_bdev=Nvme0n1" >> "$1"_flags.txt | 
					
						
							|  |  |  | 	echo "--spdk_cache_size=$CACHE_SIZE" >> "$1"_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	echo -n Start $1 test phase... | 
					
						
							|  |  |  | 	/usr/bin/time taskset 0xFFF $DB_BENCH --flagfile="$1"_flags.txt &> "$1"_db_bench.txt | 
					
						
							|  |  |  | 	echo done. | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | testdir=$(readlink -f $(dirname $0)) | 
					
						
							| 
									
										
										
										
											2017-04-04 23:20:16 +00:00
										 |  |  | rootdir=$(readlink -f $testdir/../../..) | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | source $rootdir/scripts/autotest_common.sh | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DB_BENCH_DIR=/usr/src/rocksdb | 
					
						
							|  |  |  | DB_BENCH=$DB_BENCH_DIR/db_bench | 
					
						
							|  |  |  | ROCKSDB_CONF=$testdir/rocksdb.conf | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if [ ! -e $DB_BENCH_DIR ]; then | 
					
						
							|  |  |  | 	echo $DB_BENCH_DIR does not exist, skipping rocksdb tests | 
					
						
							|  |  |  | 	exit 0 | 
					
						
							|  |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter rocksdb | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter db_bench_build | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pushd $DB_BENCH_DIR | 
					
						
							| 
									
										
										
										
											2017-05-02 21:12:44 +00:00
										 |  |  | git clean -x -f -d | 
					
						
							| 
									
										
										
										
											2017-04-28 21:40:52 +00:00
										 |  |  | $MAKE db_bench $MAKEFLAGS $MAKECONFIG DEBUG_LEVEL=0 SPDK_DIR=$rootdir | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | popd | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_exit db_bench_build | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $rootdir/etc/spdk/rocksdb.conf.in $ROCKSDB_CONF | 
					
						
							|  |  |  | $rootdir/scripts/gen_nvme.sh >> $ROCKSDB_CONF | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-27 17:02:55 +00:00
										 |  |  | trap 'rm -f $ROCKSDB_CONF; exit 1' SIGINT SIGTERM EXIT | 
					
						
							| 
									
										
										
										
											2017-05-25 18:54:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_enter mkfs | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | $rootdir/test/lib/blobfs/mkfs/mkfs $ROCKSDB_CONF Nvme0n1 | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit mkfs | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | mkdir $output_dir/rocksdb | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | RESULTS_DIR=$output_dir/rocksdb | 
					
						
							|  |  |  | CACHE_SIZE=4096 | 
					
						
							| 
									
										
										
										
											2017-12-15 00:51:55 +00:00
										 |  |  | if [ $RUN_NIGHTLY -eq 1 ]; then | 
					
						
							|  |  |  | 	DURATION=60 | 
					
						
							|  |  |  | 	NUM_KEYS=100000000 | 
					
						
							|  |  |  | else | 
					
						
							|  |  |  | 	DURATION=20 | 
					
						
							|  |  |  | 	NUM_KEYS=20000000 | 
					
						
							|  |  |  | fi | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | cd $RESULTS_DIR | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $testdir/common_flags.txt insert_flags.txt | 
					
						
							|  |  |  | echo "--benchmarks=fillseq" >> insert_flags.txt | 
					
						
							|  |  |  | echo "--threads=1" >> insert_flags.txt | 
					
						
							|  |  |  | echo "--disable_wal=1" >> insert_flags.txt | 
					
						
							|  |  |  | echo "--use_existing_db=0" >> insert_flags.txt | 
					
						
							|  |  |  | echo "--num=$NUM_KEYS" >> insert_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $testdir/common_flags.txt randread_flags.txt | 
					
						
							|  |  |  | echo "--benchmarks=readrandom" >> randread_flags.txt | 
					
						
							|  |  |  | echo "--threads=16" >> randread_flags.txt | 
					
						
							|  |  |  | echo "--duration=$DURATION" >> randread_flags.txt | 
					
						
							|  |  |  | echo "--disable_wal=1" >> randread_flags.txt | 
					
						
							|  |  |  | echo "--use_existing_db=1" >> randread_flags.txt | 
					
						
							|  |  |  | echo "--num=$NUM_KEYS" >> randread_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $testdir/common_flags.txt overwrite_flags.txt | 
					
						
							|  |  |  | echo "--benchmarks=overwrite" >> overwrite_flags.txt | 
					
						
							|  |  |  | echo "--threads=1" >> overwrite_flags.txt | 
					
						
							|  |  |  | echo "--duration=$DURATION" >> overwrite_flags.txt | 
					
						
							|  |  |  | echo "--disable_wal=1" >> overwrite_flags.txt | 
					
						
							|  |  |  | echo "--use_existing_db=1" >> overwrite_flags.txt | 
					
						
							|  |  |  | echo "--num=$NUM_KEYS" >> overwrite_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $testdir/common_flags.txt readwrite_flags.txt | 
					
						
							|  |  |  | echo "--benchmarks=readwhilewriting" >> readwrite_flags.txt | 
					
						
							|  |  |  | echo "--threads=4" >> readwrite_flags.txt | 
					
						
							|  |  |  | echo "--duration=$DURATION" >> readwrite_flags.txt | 
					
						
							|  |  |  | echo "--disable_wal=1" >> readwrite_flags.txt | 
					
						
							|  |  |  | echo "--use_existing_db=1" >> readwrite_flags.txt | 
					
						
							|  |  |  | echo "--num=$NUM_KEYS" >> readwrite_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cp $testdir/common_flags.txt writesync_flags.txt | 
					
						
							|  |  |  | echo "--benchmarks=overwrite" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--threads=1" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--duration=$DURATION" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--disable_wal=0" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--use_existing_db=1" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--sync=1" >> writesync_flags.txt | 
					
						
							|  |  |  | echo "--num=$NUM_KEYS" >> writesync_flags.txt | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_enter rocksdb_insert | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step insert | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit rocksdb_insert | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter rocksdb_overwrite | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step overwrite | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit rocksdb_overwrite | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter rocksdb_readwrite | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step readwrite | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit rocksdb_readwrite | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter rocksdb_writesync | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step writesync | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit rocksdb_writesync | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_enter rocksdb_randread | 
					
						
							| 
									
										
										
										
											2017-09-15 16:53:34 +00:00
										 |  |  | run_step randread | 
					
						
							| 
									
										
										
										
											2017-09-15 17:37:14 +00:00
										 |  |  | timing_exit rocksdb_randread | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | trap - SIGINT SIGTERM EXIT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | rm -f $ROCKSDB_CONF | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | timing_exit rocksdb |