2021-02-16 13:48:20 -08:00
|
|
|
#![allow(clippy::integer_arithmetic)]
|
2018-11-23 06:12:43 -08:00
|
|
|
#![feature(test)]
|
2019-10-18 09:28:51 -07:00
|
|
|
extern crate solana_ledger;
|
2019-11-19 20:15:37 -08:00
|
|
|
extern crate test;
|
2019-02-26 17:11:26 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
use rand::Rng;
|
2019-11-02 00:38:30 -07:00
|
|
|
use solana_ledger::{
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore::{entries_to_test_shreds, Blockstore},
|
2019-11-02 00:38:30 -07:00
|
|
|
entry::{create_ticks, Entry},
|
2019-11-13 07:14:09 -08:00
|
|
|
get_tmp_ledger_path,
|
2019-11-02 00:38:30 -07:00
|
|
|
};
|
|
|
|
use solana_sdk::{clock::Slot, hash::Hash};
|
2019-07-30 15:53:41 -07:00
|
|
|
use std::path::Path;
|
2018-11-23 06:12:43 -08:00
|
|
|
use test::Bencher;
|
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Given some shreds and a ledger at ledger_path, benchmark writing the shreds to the ledger
|
|
|
|
fn bench_write_shreds(bench: &mut Bencher, entries: Vec<Entry>, ledger_path: &Path) {
|
2020-01-13 13:13:52 -08:00
|
|
|
let blockstore =
|
|
|
|
Blockstore::open(ledger_path).expect("Expected to be able to open database ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
bench.iter(move || {
|
2019-11-18 18:05:02 -08:00
|
|
|
let shreds = entries_to_test_shreds(entries.clone(), 0, 0, true, 0);
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore.insert_shreds(shreds, None, false).unwrap();
|
2018-11-23 06:12:43 -08:00
|
|
|
});
|
|
|
|
|
2020-01-13 13:13:52 -08:00
|
|
|
Blockstore::destroy(ledger_path).expect("Expected successful database destruction");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Insert some shreds into the ledger in preparation for read benchmarks
|
2018-11-23 06:12:43 -08:00
|
|
|
fn setup_read_bench(
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore: &mut Blockstore,
|
2019-09-03 21:32:51 -07:00
|
|
|
num_small_shreds: u64,
|
|
|
|
num_large_shreds: u64,
|
2019-11-02 00:38:30 -07:00
|
|
|
slot: Slot,
|
2018-11-23 06:12:43 -08:00
|
|
|
) {
|
|
|
|
// Make some big and small entries
|
2019-10-31 13:38:50 -07:00
|
|
|
let entries = create_ticks(
|
|
|
|
num_large_shreds * 4 + num_small_shreds * 2,
|
|
|
|
0,
|
|
|
|
Hash::default(),
|
|
|
|
);
|
2019-09-03 21:32:51 -07:00
|
|
|
|
|
|
|
// Convert the entries to shreds, write the shreds to the ledger
|
2019-11-18 18:05:02 -08:00
|
|
|
let shreds = entries_to_test_shreds(entries, slot, slot.saturating_sub(1), true, 0);
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore
|
2019-11-14 00:32:07 -08:00
|
|
|
.insert_shreds(shreds, None, false)
|
2019-09-03 21:32:51 -07:00
|
|
|
.expect("Expectd successful insertion of shreds into ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Write small shreds to the ledger
|
2018-11-23 06:12:43 -08:00
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_write_small(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2018-11-23 06:12:43 -08:00
|
|
|
let num_entries = 32 * 1024;
|
2019-10-31 13:38:50 -07:00
|
|
|
let entries = create_ticks(num_entries, 0, Hash::default());
|
2019-09-03 21:32:51 -07:00
|
|
|
bench_write_shreds(bench, entries, &ledger_path);
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Write big shreds to the ledger
|
2018-11-23 06:12:43 -08:00
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_write_big(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2018-11-23 06:12:43 -08:00
|
|
|
let num_entries = 32 * 1024;
|
2019-10-31 13:38:50 -07:00
|
|
|
let entries = create_ticks(num_entries, 0, Hash::default());
|
2019-09-03 21:32:51 -07:00
|
|
|
bench_write_shreds(bench, entries, &ledger_path);
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_read_sequential(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2020-01-13 13:13:52 -08:00
|
|
|
let mut blockstore =
|
|
|
|
Blockstore::open(&ledger_path).expect("Expected to be able to open database ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Insert some big and small shreds into the ledger
|
|
|
|
let num_small_shreds = 32 * 1024;
|
|
|
|
let num_large_shreds = 32 * 1024;
|
|
|
|
let total_shreds = num_small_shreds + num_large_shreds;
|
2018-11-23 06:12:43 -08:00
|
|
|
let slot = 0;
|
2020-01-13 13:13:52 -08:00
|
|
|
setup_read_bench(&mut blockstore, num_small_shreds, num_large_shreds, slot);
|
2018-11-23 06:12:43 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
let num_reads = total_shreds / 15;
|
2018-11-23 06:12:43 -08:00
|
|
|
let mut rng = rand::thread_rng();
|
|
|
|
bench.iter(move || {
|
2019-09-03 21:32:51 -07:00
|
|
|
// Generate random starting point in the range [0, total_shreds - 1], read num_reads shreds sequentially
|
|
|
|
let start_index = rng.gen_range(0, num_small_shreds + num_large_shreds);
|
2018-11-23 06:12:43 -08:00
|
|
|
for i in start_index..start_index + num_reads {
|
2020-01-13 13:13:52 -08:00
|
|
|
let _ = blockstore.get_data_shred(slot, i as u64 % total_shreds);
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2020-01-13 13:13:52 -08:00
|
|
|
Blockstore::destroy(&ledger_path).expect("Expected successful database destruction");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_read_random(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2020-01-13 13:13:52 -08:00
|
|
|
let mut blockstore =
|
|
|
|
Blockstore::open(&ledger_path).expect("Expected to be able to open database ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Insert some big and small shreds into the ledger
|
|
|
|
let num_small_shreds = 32 * 1024;
|
|
|
|
let num_large_shreds = 32 * 1024;
|
|
|
|
let total_shreds = num_small_shreds + num_large_shreds;
|
2018-11-23 06:12:43 -08:00
|
|
|
let slot = 0;
|
2020-01-13 13:13:52 -08:00
|
|
|
setup_read_bench(&mut blockstore, num_small_shreds, num_large_shreds, slot);
|
2018-11-23 06:12:43 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
let num_reads = total_shreds / 15;
|
2018-11-23 06:12:43 -08:00
|
|
|
|
2019-09-03 21:32:51 -07:00
|
|
|
// Generate a num_reads sized random sample of indexes in range [0, total_shreds - 1],
|
2018-11-23 06:12:43 -08:00
|
|
|
// simulating random reads
|
|
|
|
let mut rng = rand::thread_rng();
|
|
|
|
let indexes: Vec<usize> = (0..num_reads)
|
2019-09-03 21:32:51 -07:00
|
|
|
.map(|_| rng.gen_range(0, total_shreds) as usize)
|
2018-11-23 06:12:43 -08:00
|
|
|
.collect();
|
|
|
|
bench.iter(move || {
|
|
|
|
for i in indexes.iter() {
|
2020-01-13 13:13:52 -08:00
|
|
|
let _ = blockstore.get_data_shred(slot, *i as u64);
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2020-01-13 13:13:52 -08:00
|
|
|
Blockstore::destroy(&ledger_path).expect("Expected successful database destruction");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
2019-09-03 21:32:51 -07:00
|
|
|
fn bench_insert_data_shred_small(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2020-01-13 13:13:52 -08:00
|
|
|
let blockstore =
|
|
|
|
Blockstore::open(&ledger_path).expect("Expected to be able to open database ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
let num_entries = 32 * 1024;
|
2019-10-31 13:38:50 -07:00
|
|
|
let entries = create_ticks(num_entries, 0, Hash::default());
|
2018-11-23 06:12:43 -08:00
|
|
|
bench.iter(move || {
|
2019-11-18 18:05:02 -08:00
|
|
|
let shreds = entries_to_test_shreds(entries.clone(), 0, 0, true, 0);
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore.insert_shreds(shreds, None, false).unwrap();
|
2018-11-23 06:12:43 -08:00
|
|
|
});
|
2020-01-13 13:13:52 -08:00
|
|
|
Blockstore::destroy(&ledger_path).expect("Expected successful database destruction");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
2019-09-03 21:32:51 -07:00
|
|
|
fn bench_insert_data_shred_big(bench: &mut Bencher) {
|
2019-02-26 17:11:26 -08:00
|
|
|
let ledger_path = get_tmp_ledger_path!();
|
2020-01-13 13:13:52 -08:00
|
|
|
let blockstore =
|
|
|
|
Blockstore::open(&ledger_path).expect("Expected to be able to open database ledger");
|
2018-11-23 06:12:43 -08:00
|
|
|
let num_entries = 32 * 1024;
|
2019-10-31 13:38:50 -07:00
|
|
|
let entries = create_ticks(num_entries, 0, Hash::default());
|
2018-11-23 06:12:43 -08:00
|
|
|
bench.iter(move || {
|
2019-11-18 18:05:02 -08:00
|
|
|
let shreds = entries_to_test_shreds(entries.clone(), 0, 0, true, 0);
|
2020-01-13 13:13:52 -08:00
|
|
|
blockstore.insert_shreds(shreds, None, false).unwrap();
|
2018-11-23 06:12:43 -08:00
|
|
|
});
|
2020-01-13 13:13:52 -08:00
|
|
|
Blockstore::destroy(&ledger_path).expect("Expected successful database destruction");
|
2018-11-23 06:12:43 -08:00
|
|
|
}
|