@ -28,6 +28,7 @@ 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)  
			
		
	
		
		
			
				
					
					cache_size = $(( 1  *  G)) cache_size = $(( 1  *  G))  
			
		
	
		
		
			
				
					
					duration = ${ DURATION :- 0 } duration = ${ DURATION :- 0 }  
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -56,8 +57,6 @@ const_params=" 
			
		
	
		
		
			
				
					
					  --target_file_size_base= $(( 128  *  M))  \    --target_file_size_base= $(( 128  *  M))  \   
			
		
	
		
		
			
				
					
					  --max_bytes_for_level_base= $(( 1  *  G))  \    --max_bytes_for_level_base= $(( 1  *  G))  \   
			
		
	
		
		
			
				
					
					  \    \   
			
		
	
		
		
			
				
					
					  --sync= 0  \   
			
		
	
		
		
			
				
					
					  --disable_data_sync= 1  \   
			
		
	
		
		
			
				
					
					  --verify_checksum= 1  \    --verify_checksum= 1  \   
			
		
	
		
		
			
				
					
					  --delete_obsolete_files_period_micros= $(( 60  *  M))  \    --delete_obsolete_files_period_micros= $(( 60  *  M))  \   
			
		
	
		
		
			
				
					
					  --max_grandparent_overlap_factor= 10  \    --max_grandparent_overlap_factor= 10  \   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -93,6 +92,7 @@ function run_bulkload { 
			
		
	
		
		
			
				
					
					       --use_existing_db= 0  \         --use_existing_db= 0  \   
			
		
	
		
		
			
				
					
					       --num= $num_keys  \         --num= $num_keys  \   
			
		
	
		
		
			
				
					
					       --disable_auto_compactions= 1  \         --disable_auto_compactions= 1  \   
			
		
	
		
		
			
				
					
					       --sync= 0  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 1  \         --disable_data_sync= 1  \   
			
		
	
		
		
			
				
					
					       --threads= 1  2>& 1  |  tee $output_dir /benchmark_bulkload_fillrandom.log"         --threads= 1  2>& 1  |  tee $output_dir /benchmark_bulkload_fillrandom.log"   
			
		
	
		
		
			
				
					
					  echo  $cmd  |  tee $output_dir /benchmark_bulkload_fillrandom.log   echo  $cmd  |  tee $output_dir /benchmark_bulkload_fillrandom.log  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -102,6 +102,7 @@ function run_bulkload { 
			
		
	
		
		
			
				
					
					       --use_existing_db= 1  \         --use_existing_db= 1  \   
			
		
	
		
		
			
				
					
					       --num= $num_keys  \         --num= $num_keys  \   
			
		
	
		
		
			
				
					
					       --disable_auto_compactions= 1  \         --disable_auto_compactions= 1  \   
			
		
	
		
		
			
				
					
					       --sync= 0  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 1  \         --disable_data_sync= 1  \   
			
		
	
		
		
			
				
					
					       --threads= 1  2>& 1  |  tee $output_dir /benchmark_bulkload_compact.log"         --threads= 1  2>& 1  |  tee $output_dir /benchmark_bulkload_compact.log"   
			
		
	
		
		
			
				
					
					  echo  $cmd  |  tee $output_dir /benchmark_bulkload_compact.log   echo  $cmd  |  tee $output_dir /benchmark_bulkload_compact.log  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -113,6 +114,8 @@ 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  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 0  \   
			
		
	
		
		
			
				
					
					       --threads= 1  2>& 1  |  tee $output_dir /benchmark_fillseq.log"         --threads= 1  2>& 1  |  tee $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   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -123,6 +126,8 @@ 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  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 0  \   
			
		
	
		
		
			
				
					
					       --threads= 1  2>& 1  |  tee $output_dir /benchmark_overwrite.log"         --threads= 1  2>& 1  |  tee $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   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -133,6 +138,8 @@ 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  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 0  \   
			
		
	
		
		
			
				
					
					       --threads= 1  2>& 1  |  tee $output_dir /benchmark_filluniquerandom.log"         --threads= 1  2>& 1  |  tee $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   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -155,6 +162,8 @@ 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  \   
			
		
	
		
		
			
				
					
					       --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 $output_dir /benchmark_readwhilewriting.log"   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -162,13 +171,27 @@ function run_readwhilewriting { 
			
		
	
		
		
			
				
					
					  eval  $cmd    eval  $cmd   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					function  run_rangescanwhilewriting {  
			
		
	
		
		
			
				
					
					  echo  " Range scan  $num_keys  random keys from database whiling writing.. "   
			
		
	
		
		
			
				
					
					  cmd = " ./db_bench  $params_r  --benchmarks=seekrandomwhilewriting  \   
			
		
	
		
		
			
				
					
					       --use_existing_db= 1  \   
			
		
	
		
		
			
				
					
					       --num= $num_keys  \   
			
		
	
		
		
			
				
					
					       --sync= 1  \   
			
		
	
		
		
			
				
					
					       --disable_data_sync= 0  \   
			
		
	
		
		
			
				
					
					       --threads= $num_read_threads  \   
			
		
	
		
		
			
				
					
					       --writes_per_second= $writes_per_second  \   
			
		
	
		
		
			
				
					
					       --seek_nexts= $num_nexts_per_seek  \   
			
		
	
		
		
			
				
					
					       2>& 1  |  tee $output_dir /benchmark_rangescanwhilewriting.log"   
			
		
	
		
		
			
				
					
					  echo  $cmd  |  tee $output_dir /benchmark_rangescanwhilewriting.log  
			
		
	
		
		
			
				
					
					  eval  $cmd   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					function  now( )  { function  now( )  {  
			
		
	
		
		
			
				
					
					  echo  ` date +"%s" `    echo  ` date +"%s" `   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					report = " $output_dir /report.txt " report = " $output_dir /report.txt "  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# print start time  
			
		
	
		
		
			
				
					
					echo  "===== Benchmark =====" echo  "===== Benchmark ====="  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# Run!!! # Run!!!  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -188,6 +211,8 @@ for job in ${jobs[@]}; do 
			
		
	
		
		
			
				
					
					    run_readrandom     run_readrandom  
			
		
	
		
		
			
				
					
					  elif  [  $job  =  readwhilewriting ] ;  then    elif  [  $job  =  readwhilewriting ] ;  then   
			
		
	
		
		
			
				
					
					    run_readwhilewriting     run_readwhilewriting  
			
		
	
		
		
			
				
					
					  elif  [  $job  =  rangescanwhilewriting ] ;  then   
			
		
	
		
		
			
				
					
					    run_rangescanwhilewriting  
			
		
	
		
		
			
				
					
					  else    else   
			
		
	
		
		
			
				
					
					    echo  " unknown job  $job "      echo  " unknown job  $job "   
			
		
	
		
		
			
				
					
					    exit     exit  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -195,12 +220,17 @@ for job in ${jobs[@]}; do 
			
		
	
		
		
			
				
					
					  end = $( now)    end = $( now)   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  echo  " Complete  $job  in  $(( end-start))  seconds "  |  tee -a $report    echo  " Complete  $job  in  $(( end-start))  seconds "  |  tee -a $report   
			
		
	
		
		
			
				
					
					  if  [ [  $job  =  readrandom ||  $job  =  readwhilewriting ] ] ;  then    if  [ [  $job  =  readrandom ||  $job  =  readwhilewriting ||  $job  = =  rangescanwhilewriting ] ] ;  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}' )      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) ;   
			
		
	
		
		
			
				
					
					    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   
			
		
	
		
		
			
				
					
					    echo  " QPS =  $qps  ops/sec "  |  tee -a $report      echo  " QPS =  $qps  ops/sec "  |  tee -a $report   
			
		
	
		
		
			
				
					
					    echo  " Avg Latency =  $lat  micros/op  "  |  tee -a $report   
			
		
	
		
		
			
				
					
					  fi    fi   
			
		
	
		
		
			
				
					
					done done