@ -664,7 +664,7 @@ class Stats {
void SetId ( int id ) { id_ = id ; }
void SetId ( int id ) { id_ = id ; }
void SetExcludeFromMerge ( ) { exclude_from_merge_ = true ; }
void SetExcludeFromMerge ( ) { exclude_from_merge_ = true ; }
void FinishedSingle Op ( DB * db ) {
void FinishedOps ( DB * db , int64_t num_ops ) {
if ( FLAGS_histogram ) {
if ( FLAGS_histogram ) {
double now = FLAGS_env - > NowMicros ( ) ;
double now = FLAGS_env - > NowMicros ( ) ;
double micros = now - last_op_finish_ ;
double micros = now - last_op_finish_ ;
@ -676,7 +676,7 @@ class Stats {
last_op_finish_ = now ;
last_op_finish_ = now ;
}
}
done_ + + ;
done_ + = num_ops ;
if ( done_ > = next_report_ ) {
if ( done_ > = next_report_ ) {
if ( ! FLAGS_stats_interval ) {
if ( ! FLAGS_stats_interval ) {
if ( next_report_ < 1000 ) next_report_ + = 100 ;
if ( next_report_ < 1000 ) next_report_ + = 100 ;
@ -722,7 +722,7 @@ class Stats {
void Report ( const Slice & name ) {
void Report ( const Slice & name ) {
// Pretend at least one op was done in case we are running a benchmark
// Pretend at least one op was done in case we are running a benchmark
// that does not call FinishedSingle Op().
// that does not call FinishedOps ().
if ( done_ < 1 ) done_ = 1 ;
if ( done_ < 1 ) done_ = 1 ;
std : : string extra ;
std : : string extra ;
@ -1391,7 +1391,7 @@ class Benchmark {
uint32_t crc = 0 ;
uint32_t crc = 0 ;
while ( bytes < 500 * 1048576 ) {
while ( bytes < 500 * 1048576 ) {
crc = crc32c : : Value ( data . data ( ) , size ) ;
crc = crc32c : : Value ( data . data ( ) , size ) ;
thread - > stats . FinishedSingle Op ( nullptr ) ;
thread - > stats . FinishedOps ( nullptr , 1 ) ;
bytes + = size ;
bytes + = size ;
}
}
// Print so result is not dead
// Print so result is not dead
@ -1410,7 +1410,7 @@ class Benchmark {
unsigned int xxh32 = 0 ;
unsigned int xxh32 = 0 ;
while ( bytes < 500 * 1048576 ) {
while ( bytes < 500 * 1048576 ) {
xxh32 = XXH32 ( data . data ( ) , size , 0 ) ;
xxh32 = XXH32 ( data . data ( ) , size , 0 ) ;
thread - > stats . FinishedSingle Op ( nullptr ) ;
thread - > stats . FinishedOps ( nullptr , 1 ) ;
bytes + = size ;
bytes + = size ;
}
}
// Print so result is not dead
// Print so result is not dead
@ -1431,7 +1431,7 @@ class Benchmark {
ptr = ap . Acquire_Load ( ) ;
ptr = ap . Acquire_Load ( ) ;
}
}
count + + ;
count + + ;
thread - > stats . FinishedSingle Op ( nullptr ) ;
thread - > stats . FinishedOps ( nullptr , 1 ) ;
}
}
if ( ptr = = nullptr ) exit ( 1 ) ; // Disable unused variable warning.
if ( ptr = = nullptr ) exit ( 1 ) ; // Disable unused variable warning.
}
}
@ -1472,7 +1472,7 @@ class Benchmark {
}
}
produced + = compressed . size ( ) ;
produced + = compressed . size ( ) ;
bytes + = input . size ( ) ;
bytes + = input . size ( ) ;
thread - > stats . FinishedSingle Op ( nullptr ) ;
thread - > stats . FinishedOps ( nullptr , 1 ) ;
}
}
if ( ! ok ) {
if ( ! ok ) {
@ -1553,7 +1553,7 @@ class Benchmark {
}
}
delete [ ] uncompressed ;
delete [ ] uncompressed ;
bytes + = input . size ( ) ;
bytes + = input . size ( ) ;
thread - > stats . FinishedSingle Op ( nullptr ) ;
thread - > stats . FinishedOps ( nullptr , 1 ) ;
}
}
if ( ! ok ) {
if ( ! ok ) {
@ -1862,9 +1862,9 @@ class Benchmark {
GenerateKeyFromInt ( key_gens [ id ] - > Next ( ) , FLAGS_num , & key ) ;
GenerateKeyFromInt ( key_gens [ id ] - > Next ( ) , FLAGS_num , & key ) ;
batch . Put ( key , gen . Generate ( value_size_ ) ) ;
batch . Put ( key , gen . Generate ( value_size_ ) ) ;
bytes + = value_size_ + key_size_ ;
bytes + = value_size_ + key_size_ ;
thread - > stats . FinishedSingleOp ( db_to_write ) ;
}
}
s = db_to_write - > Write ( write_options_ , & batch ) ;
s = db_to_write - > Write ( write_options_ , & batch ) ;
thread - > stats . FinishedOps ( db_to_write , entries_per_batch_ ) ;
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
@ -1889,7 +1889,7 @@ class Benchmark {
int64_t bytes = 0 ;
int64_t bytes = 0 ;
for ( iter - > SeekToFirst ( ) ; i < reads_ & & iter - > Valid ( ) ; iter - > Next ( ) ) {
for ( iter - > SeekToFirst ( ) ; i < reads_ & & iter - > Valid ( ) ; iter - > Next ( ) ) {
bytes + = iter - > key ( ) . size ( ) + iter - > value ( ) . size ( ) ;
bytes + = iter - > key ( ) . size ( ) + iter - > value ( ) . size ( ) ;
thread - > stats . FinishedSingle Op ( db ) ;
thread - > stats . FinishedOps ( db , 1 ) ;
+ + i ;
+ + i ;
}
}
delete iter ;
delete iter ;
@ -1912,7 +1912,7 @@ class Benchmark {
int64_t bytes = 0 ;
int64_t bytes = 0 ;
for ( iter - > SeekToLast ( ) ; i < reads_ & & iter - > Valid ( ) ; iter - > Prev ( ) ) {
for ( iter - > SeekToLast ( ) ; i < reads_ & & iter - > Valid ( ) ; iter - > Prev ( ) ) {
bytes + = iter - > key ( ) . size ( ) + iter - > value ( ) . size ( ) ;
bytes + = iter - > key ( ) . size ( ) + iter - > value ( ) . size ( ) ;
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
+ + i ;
+ + i ;
}
}
delete iter ;
delete iter ;
@ -1935,7 +1935,7 @@ class Benchmark {
if ( db - > Get ( options , key , & value ) . ok ( ) ) {
if ( db - > Get ( options , key , & value ) . ok ( ) ) {
found + + ;
found + + ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;
@ -1995,7 +1995,7 @@ class Benchmark {
DB * db = SelectDB ( thread ) ;
DB * db = SelectDB ( thread ) ;
Iterator * iter = db - > NewIterator ( options ) ;
Iterator * iter = db - > NewIterator ( options ) ;
delete iter ;
delete iter ;
thread - > stats . FinishedSingle Op ( db ) ;
thread - > stats . FinishedOps ( db , 1 ) ;
}
}
}
}
@ -2059,7 +2059,7 @@ class Benchmark {
if ( iter_to_use - > Valid ( ) & & iter_to_use - > key ( ) . compare ( key ) = = 0 ) {
if ( iter_to_use - > Valid ( ) & & iter_to_use - > key ( ) . compare ( key ) = = 0 ) {
found + + ;
found + + ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
delete single_iter ;
delete single_iter ;
for ( auto iter : multi_iters ) {
for ( auto iter : multi_iters ) {
@ -2097,9 +2097,9 @@ class Benchmark {
const int64_t k = seq ? i + j : ( thread - > rand . Next ( ) % FLAGS_num ) ;
const int64_t k = seq ? i + j : ( thread - > rand . Next ( ) % FLAGS_num ) ;
GenerateKeyFromInt ( k , FLAGS_num , & key ) ;
GenerateKeyFromInt ( k , FLAGS_num , & key ) ;
batch . Delete ( key ) ;
batch . Delete ( key ) ;
thread - > stats . FinishedSingleOp ( db ) ;
}
}
auto s = db - > Write ( write_options_ , & batch ) ;
auto s = db - > Write ( write_options_ , & batch ) ;
thread - > stats . FinishedOps ( db , entries_per_batch_ ) ;
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
fprintf ( stderr , " del error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " del error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
@ -2159,7 +2159,7 @@ class Benchmark {
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
+ + num_writes ;
+ + num_writes ;
if ( writes_per_second_by_10 & & num_writes > = writes_per_second_by_10 ) {
if ( writes_per_second_by_10 & & num_writes > = writes_per_second_by_10 ) {
@ -2319,7 +2319,7 @@ class Benchmark {
deletes_done + + ;
deletes_done + + ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;
snprintf ( msg , sizeof ( msg ) ,
snprintf ( msg , sizeof ( msg ) ,
@ -2377,7 +2377,7 @@ class Benchmark {
put_weight - - ;
put_weight - - ;
writes_done + + ;
writes_done + + ;
}
}
thread - > stats . FinishedSingle Op ( db ) ;
thread - > stats . FinishedOps ( db , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;
snprintf ( msg , sizeof ( msg ) , " ( reads:% " PRIu64 " writes:% " PRIu64 \
snprintf ( msg , sizeof ( msg ) , " ( reads:% " PRIu64 " writes:% " PRIu64 \
@ -2411,7 +2411,7 @@ class Benchmark {
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
}
}
thread - > stats . FinishedSingle Op ( db ) ;
thread - > stats . FinishedOps ( db , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;
snprintf ( msg , sizeof ( msg ) ,
snprintf ( msg , sizeof ( msg ) ,
@ -2458,7 +2458,7 @@ class Benchmark {
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " put error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;
@ -2494,7 +2494,7 @@ class Benchmark {
fprintf ( stderr , " merge error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
fprintf ( stderr , " merge error: %s \n " , s . ToString ( ) . c_str ( ) ) ;
exit ( 1 ) ;
exit ( 1 ) ;
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
// Print some statistics
// Print some statistics
@ -2555,7 +2555,7 @@ class Benchmark {
}
}
thread - > stats . FinishedSingle Op ( db_ ) ;
thread - > stats . FinishedOps ( db_ , 1 ) ;
}
}
char msg [ 100 ] ;
char msg [ 100 ] ;