@ -79,6 +79,7 @@ DEFINE_string(benchmarks, 
			
		
	
		
		
			
				
					
					              " readtocache, "                " readtocache, "   
			
		
	
		
		
			
				
					
					              " readreverse, "                " readreverse, "   
			
		
	
		
		
			
				
					
					              " readwhilewriting, "                " readwhilewriting, "   
			
		
	
		
		
			
				
					
					              " readwhilemerging, "   
			
		
	
		
		
			
				
					
					              " readrandomwriterandom, "                " readrandomwriterandom, "   
			
		
	
		
		
			
				
					
					              " updaterandom, "                " updaterandom, "   
			
		
	
		
		
			
				
					
					              " randomwithverify, "                " randomwithverify, "   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -113,6 +114,8 @@ DEFINE_string(benchmarks, 
			
		
	
		
		
			
				
					
					              " of DB \n "                " of DB \n "   
			
		
	
		
		
			
				
					
					              " \t readwhilewriting      -- 1 writer, N threads doing random  "                " \t readwhilewriting      -- 1 writer, N threads doing random  "   
			
		
	
		
		
			
				
					
					              " reads \n "                " reads \n "   
			
		
	
		
		
			
				
					
					              " \t readwhilemerging      -- 1 merger, N threads doing random  "   
			
		
	
		
		
			
				
					
					              " reads \n "   
			
		
	
		
		
			
				
					
					              " \t readrandomwriterandom -- N threads doing random-read,  "                " \t readrandomwriterandom -- N threads doing random-read,  "   
			
		
	
		
		
			
				
					
					              " random-write \n "                " random-write \n "   
			
		
	
		
		
			
				
					
					              " \t prefixscanrandom      -- prefix scan N times in random order \n "                " \t prefixscanrandom      -- prefix scan N times in random order \n "   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -180,6 +183,10 @@ DEFINE_int32(seek_nexts, 0, 
			
		
	
		
		
			
				
					
					             " How many times to call Next() after Seek() in  "               " How many times to call Next() after Seek() in  "   
			
		
	
		
		
			
				
					
					             " fillseekseq and seekrandom " ) ;               " fillseekseq and seekrandom " ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					DEFINE_bool ( reverse_iterator ,  false ,  
			
		
	
		
		
			
				
					
					            " When true use Prev rather than Next for iterators that do  "   
			
		
	
		
		
			
				
					
					            " Seek and then Next " ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					DEFINE_bool ( use_uint64_comparator ,  false ,  " use Uint64 user comparator " ) ; DEFINE_bool ( use_uint64_comparator ,  false ,  " use Uint64 user comparator " ) ;  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					DEFINE_int64 ( batch_size ,  1 ,  " Batch size " ) ; DEFINE_int64 ( batch_size ,  1 ,  " Batch size " ) ;  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -316,8 +323,9 @@ static class std::shared_ptr<rocksdb::Statistics> dbstats; 
			
		
	
		
		
			
				
					
					DEFINE_int64 ( writes ,  - 1 ,  " Number of write operations to do. If negative, do " DEFINE_int64 ( writes ,  - 1 ,  " Number of write operations to do. If negative, do "  
			
		
	
		
		
			
				
					
					             "  --num reads. " ) ;               "  --num reads. " ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					DEFINE_int32 ( writes_per_second ,  0 ,  " Per-thread rate limit on writes per second. " DEFINE_int32 ( writes_per_second ,  0 ,  " Per-thread rate limit on writes and merges  "  
			
				
				
			
		
	
		
		
			
				
					
					             "  No limit when <= 0. Only for the readwhilewriting test. " ) ;               "   per second. No limit when <= 0. Only for the readwhilewriting  "   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					             "   and readwhilemerging tests. " ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					DEFINE_bool ( sync ,  false ,  " Sync all writes to disk " ) ; DEFINE_bool ( sync ,  false ,  " Sync all writes to disk " ) ;  
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -560,6 +568,11 @@ DEFINE_bool(identity_as_first_hash, false, "the first hash function of cuckoo " 
			
		
	
		
		
			
				
					
					            " table becomes an identity function. This is only valid when key  "              " table becomes an identity function. This is only valid when key  "   
			
		
	
		
		
			
				
					
					            " is 8 bytes " ) ;              " is 8 bytes " ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					enum  PutOrMerge  {  
			
		
	
		
		
			
				
					
					  kPut ,   
			
		
	
		
		
			
				
					
					  kMerge   
			
		
	
		
		
			
				
					
					} ;  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					enum  RepFactory  { enum  RepFactory  {  
			
		
	
		
		
			
				
					
					  kSkipList ,    kSkipList ,   
			
		
	
		
		
			
				
					
					  kPrefixHash ,    kPrefixHash ,   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1588,6 +1601,9 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					      }  else  if  ( name  = =  Slice ( " readwhilewriting " ) )  {        }  else  if  ( name  = =  Slice ( " readwhilewriting " ) )  {   
			
		
	
		
		
			
				
					
					        num_threads + + ;   // Add extra thread for writing
          num_threads + + ;   // Add extra thread for writing
   
			
		
	
		
		
			
				
					
					        method  =  & Benchmark : : ReadWhileWriting ;          method  =  & Benchmark : : ReadWhileWriting ;   
			
		
	
		
		
			
				
					
					      }  else  if  ( name  = =  Slice ( " readwhilemerging " ) )  {   
			
		
	
		
		
			
				
					
					        num_threads + + ;   // Add extra thread for writing
   
			
		
	
		
		
			
				
					
					        method  =  & Benchmark : : ReadWhileMerging ;   
			
		
	
		
		
			
				
					
					      }  else  if  ( name  = =  Slice ( " readrandomwriterandom " ) )  {        }  else  if  ( name  = =  Slice ( " readrandomwriterandom " ) )  {   
			
		
	
		
		
			
				
					
					        method  =  & Benchmark : : ReadRandomWriteRandom ;          method  =  & Benchmark : : ReadRandomWriteRandom ;   
			
		
	
		
		
			
				
					
					      }  else  if  ( name  = =  Slice ( " readrandommergerandom " ) )  {        }  else  if  ( name  = =  Slice ( " readrandommergerandom " ) )  {   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2605,7 +2621,7 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					    if  ( thread - > tid  >  0 )  {      if  ( thread - > tid  >  0 )  {   
			
		
	
		
		
			
				
					
					      IteratorCreation ( thread ) ;        IteratorCreation ( thread ) ;   
			
		
	
		
		
			
				
					
					    }  else  {      }  else  {   
			
		
	
		
		
			
				
					
					      BGWriter ( thread ) ;        BGWriter ( thread ,  kPut ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2668,7 +2684,12 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					        Slice  value  =  iter_to_use - > value ( ) ;          Slice  value  =  iter_to_use - > value ( ) ;   
			
		
	
		
		
			
				
					
					        memcpy ( value_buffer ,  value . data ( ) ,          memcpy ( value_buffer ,  value . data ( ) ,   
			
		
	
		
		
			
				
					
					               std : : min ( value . size ( ) ,  sizeof ( value_buffer ) ) ) ;                 std : : min ( value . size ( ) ,  sizeof ( value_buffer ) ) ) ;   
			
		
	
		
		
			
				
					
					        iter_to_use - > Next ( ) ;  
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        if  ( ! FLAGS_reverse_iterator )  {   
			
		
	
		
		
			
				
					
					          iter_to_use - > Next ( ) ;   
			
		
	
		
		
			
				
					
					        }  else  {   
			
		
	
		
		
			
				
					
					          iter_to_use - > Prev ( ) ;   
			
		
	
		
		
			
				
					
					        }   
			
		
	
		
		
			
				
					
					        assert ( iter_to_use - > status ( ) . ok ( ) ) ;          assert ( iter_to_use - > status ( ) . ok ( ) ) ;   
			
		
	
		
		
			
				
					
					      }        }   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -2692,7 +2713,7 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					    if  ( thread - > tid  >  0 )  {      if  ( thread - > tid  >  0 )  {   
			
		
	
		
		
			
				
					
					      SeekRandom ( thread ) ;        SeekRandom ( thread ) ;   
			
		
	
		
		
			
				
					
					    }  else  {      }  else  {   
			
		
	
		
		
			
				
					
					      BGWriter ( thread ) ;        BGWriter ( thread ,  kPut ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2733,11 +2754,19 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					    if  ( thread - > tid  >  0 )  {      if  ( thread - > tid  >  0 )  {   
			
		
	
		
		
			
				
					
					      ReadRandom ( thread ) ;        ReadRandom ( thread ) ;   
			
		
	
		
		
			
				
					
					    }  else  {      }  else  {   
			
		
	
		
		
			
				
					
					      BGWriter ( thread ) ;        BGWriter ( thread ,  kPut ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  void  BGWriter ( ThreadState *  thread )  {    void  ReadWhileMerging ( ThreadState *  thread )  {   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    if  ( thread - > tid  >  0 )  {   
			
		
	
		
		
			
				
					
					      ReadRandom ( thread ) ;   
			
		
	
		
		
			
				
					
					    }  else  {   
			
		
	
		
		
			
				
					
					      BGWriter ( thread ,  kMerge ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  void  BGWriter ( ThreadState *  thread ,  enum  PutOrMerge  write_merge )  {   
			
		
	
		
		
			
				
					
					    // Special thread that keeps writing until other threads are done.
      // Special thread that keeps writing until other threads are done.
   
			
		
	
		
		
			
				
					
					    RandomGenerator  gen ;      RandomGenerator  gen ;   
			
		
	
		
		
			
				
					
					    double  last  =  FLAGS_env - > NowMicros ( ) ;      double  last  =  FLAGS_env - > NowMicros ( ) ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2767,9 +2796,16 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					      }        }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      GenerateKeyFromInt ( thread - > rand . Next ( )  %  FLAGS_num ,  FLAGS_num ,  & key ) ;        GenerateKeyFromInt ( thread - > rand . Next ( )  %  FLAGS_num ,  FLAGS_num ,  & key ) ;   
			
		
	
		
		
			
				
					
					      Status  s  =  db - > Put ( write_options_ ,  key ,  gen . Generate ( value_size_ ) ) ;        Status  s ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      if  ( write_merge  = =  kPut )  {   
			
		
	
		
		
			
				
					
					          s  =  db - > Put ( write_options_ ,  key ,  gen . Generate ( value_size_ ) ) ;   
			
		
	
		
		
			
				
					
					      }  else  {   
			
		
	
		
		
			
				
					
					          s  =  db - > Merge ( write_options_ ,  key ,  gen . Generate ( value_size_ ) ) ;   
			
		
	
		
		
			
				
					
					      }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      if  ( ! s . ok ( ) )  {        if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					        fprintf ( stderr ,  " put error: %s \n " ,  s . ToString ( ) . c_str ( ) ) ;          fprintf ( stderr ,  " put or merge  error: %s \n " ,  s . ToString ( ) . c_str ( ) ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        exit ( 1 ) ;          exit ( 1 ) ;   
			
		
	
		
		
			
				
					
					      }        }   
			
		
	
		
		
			
				
					
					      thread - > stats . FinishedOps ( & db_ ,  db_ . db ,  1 ) ;        thread - > stats . FinishedOps ( & db_ ,  db_ . db ,  1 ) ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -3207,7 +3243,11 @@ class Benchmark { 
			
		
	
		
		
			
				
					
					      thread - > stats . FinishedOps ( nullptr ,  db ,  1 ) ;        thread - > stats . FinishedOps ( nullptr ,  db ,  1 ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      for  ( int  j  =  0 ;  j  <  FLAGS_seek_nexts  & &  i  +  1  <  FLAGS_num ;  + + j )  {        for  ( int  j  =  0 ;  j  <  FLAGS_seek_nexts  & &  i  +  1  <  FLAGS_num ;  + + j )  {   
			
		
	
		
		
			
				
					
					        iter - > Next ( ) ;          if  ( ! FLAGS_reverse_iterator )  {   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					          iter - > Next ( ) ;   
			
		
	
		
		
			
				
					
					        }  else  {   
			
		
	
		
		
			
				
					
					          iter - > Prev ( ) ;   
			
		
	
		
		
			
				
					
					        }   
			
		
	
		
		
			
				
					
					        GenerateKeyFromInt ( + + i ,  FLAGS_num ,  & key ) ;          GenerateKeyFromInt ( + + i ,  FLAGS_num ,  & key ) ;   
			
		
	
		
		
			
				
					
					        assert ( iter - > Valid ( )  & &  iter - > key ( )  = =  key ) ;          assert ( iter - > Valid ( )  & &  iter - > key ( )  = =  key ) ;   
			
		
	
		
		
			
				
					
					        thread - > stats . FinishedOps ( nullptr ,  db ,  1 ) ;          thread - > stats . FinishedOps ( nullptr ,  db ,  1 ) ;