Improve RangeDelAggregator benchmarks (#4395)

Summary:
Improve time measurements for AddTombstones to only include the
call and not the VectorIterator setup. Also add a new
add_tombstones_per_run flag to call AddTombstones multiple times per
aggregator, which will help simulate more realistic workloads.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/4395

Differential Revision: D9996811

Pulled By: abhimadan

fbshipit-source-id: 5865a95c323fbd9b3606493013664b4890fe5a02
main
Abhishek Madan 6 years ago committed by Facebook Github Bot
parent 04d373b260
commit 3c350a7cf0
  1. 29
      db/range_del_aggregator_bench.cc

@ -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;

Loading…
Cancel
Save