@ -52,6 +52,9 @@ DEFINE_int32(seed, 0, "random number generator seed");
DEFINE_int32 ( should_deletes_per_run , 1 , " number of ShouldDelete calls per run " ) ;
DEFINE_int32 ( should_deletes_per_run , 1 , " number of ShouldDelete calls per run " ) ;
DEFINE_int32 ( add_tombstones_per_run , 1 ,
" number of AddTombstones calls per run " ) ;
namespace {
namespace {
struct Stats {
struct Stats {
@ -65,8 +68,9 @@ std::ostream& operator<<(std::ostream& os, const Stats& s) {
fmt_holder . copyfmt ( os ) ;
fmt_holder . copyfmt ( os ) ;
os < < std : : left ;
os < < std : : left ;
os < < std : : setw ( 25 )
os < < std : : setw ( 25 ) < < " AddTombstones: "
< < " AddTombstones: " < < s . time_add_tombstones / ( FLAGS_num_runs * 1.0e3 )
< < s . time_add_tombstones /
( FLAGS_add_tombstones_per_run * FLAGS_num_runs * 1.0e3 )
< < " us \n " ;
< < " us \n " ;
os < < std : : setw ( 25 ) < < " ShouldDelete (first): "
os < < std : : setw ( 25 ) < < " ShouldDelete (first): "
< < s . time_first_should_delete / ( FLAGS_num_runs * 1.0e3 ) < < " us \n " ;
< < s . time_first_should_delete / ( FLAGS_num_runs * 1.0e3 ) < < " us \n " ;
@ -133,7 +137,7 @@ struct TombstoneStartKeyComparator {
const Comparator * cmp ;
const Comparator * cmp ;
} ;
} ;
void AddTombstones ( RangeDelAggregator * range_del_agg ,
std : : unique_ptr < InternalIterator > MakeRangeDelIterator (
const std : : vector < PersistentRangeTombstone > & range_dels ) {
const std : : vector < PersistentRangeTombstone > & range_dels ) {
std : : vector < std : : string > keys , values ;
std : : vector < std : : string > keys , values ;
for ( const auto & range_del : range_dels ) {
for ( const auto & range_del : range_dels ) {
@ -141,9 +145,8 @@ void AddTombstones(RangeDelAggregator* range_del_agg,
keys . push_back ( key_and_value . first . Encode ( ) . ToString ( ) ) ;
keys . push_back ( key_and_value . first . Encode ( ) . ToString ( ) ) ;
values . push_back ( key_and_value . second . ToString ( ) ) ;
values . push_back ( key_and_value . second . ToString ( ) ) ;
}
}
std : : unique_ptr < test : : VectorIterator > range_del_iter (
return std : : unique_ptr < test : : VectorIterator > (
new test : : VectorIterator ( keys , values ) ) ;
new test : : VectorIterator ( keys , values ) ) ;
range_del_agg - > AddTombstones ( std : : move ( range_del_iter ) ) ;
}
}
// convert long to a big-endian slice key
// convert long to a big-endian slice key
@ -171,10 +174,14 @@ int main(int argc, char** argv) {
std : : default_random_engine random_gen ( FLAGS_seed ) ;
std : : default_random_engine random_gen ( FLAGS_seed ) ;
std : : normal_distribution < double > normal_dist ( FLAGS_tombstone_width_mean ,
std : : normal_distribution < double > normal_dist ( FLAGS_tombstone_width_mean ,
FLAGS_tombstone_width_stddev ) ;
FLAGS_tombstone_width_stddev ) ;
std : : vector < rocksdb : : PersistentRangeTombstone > persistent_range_tombstones (
std : : vector < std : : vector < rocksdb : : PersistentRangeTombstone > >
all_persistent_range_tombstones ( FLAGS_add_tombstones_per_run ) ;
for ( int i = 0 ; i < FLAGS_add_tombstones_per_run ; i + + ) {
all_persistent_range_tombstones [ i ] =
std : : vector < rocksdb : : PersistentRangeTombstone > (
FLAGS_num_range_tombstones ) ;
FLAGS_num_range_tombstones ) ;
auto mode =
}
FLAGS_use_collapsed
auto mode = FLAGS_use_collapsed
? rocksdb : : RangeDelPositioningMode : : kForwardTraversal
? rocksdb : : RangeDelPositioningMode : : kForwardTraversal
: rocksdb : : RangeDelPositioningMode : : kFullScan ;
: rocksdb : : RangeDelPositioningMode : : kFullScan ;
@ -183,6 +190,7 @@ int main(int argc, char** argv) {
rocksdb : : RangeDelAggregator range_del_agg ( icmp , { } /* snapshots */ ,
rocksdb : : RangeDelAggregator range_del_agg ( icmp , { } /* snapshots */ ,
FLAGS_use_collapsed ) ;
FLAGS_use_collapsed ) ;
for ( auto & persistent_range_tombstones : all_persistent_range_tombstones ) {
// TODO(abhimadan): consider whether creating the range tombstones right
// TODO(abhimadan): consider whether creating the range tombstones right
// before AddTombstones is artificially warming the cache compared to
// before AddTombstones is artificially warming the cache compared to
// real workloads.
// real workloads.
@ -193,10 +201,13 @@ int main(int argc, char** argv) {
rocksdb : : Key ( start ) , rocksdb : : Key ( end ) , j ) ;
rocksdb : : Key ( start ) , rocksdb : : Key ( end ) , j ) ;
}
}
auto range_del_iter =
rocksdb : : MakeRangeDelIterator ( persistent_range_tombstones ) ;
rocksdb : : StopWatchNano stop_watch_add_tombstones ( rocksdb : : Env : : Default ( ) ,
rocksdb : : StopWatchNano stop_watch_add_tombstones ( rocksdb : : Env : : Default ( ) ,
true /* auto_start */ ) ;
true /* auto_start */ ) ;
rocksdb : : AddTombstones ( & range_del_agg , persistent_range_tombstones ) ;
range_del_agg . AddTombstones ( std : : move ( range_del_iter ) ) ;
stats . time_add_tombstones + = stop_watch_add_tombstones . ElapsedNanos ( ) ;
stats . time_add_tombstones + = stop_watch_add_tombstones . ElapsedNanos ( ) ;
}
rocksdb : : ParsedInternalKey parsed_key ;
rocksdb : : ParsedInternalKey parsed_key ;
parsed_key . sequence = FLAGS_num_range_tombstones / 2 ;
parsed_key . sequence = FLAGS_num_range_tombstones / 2 ;