[RocksDB] Add mmap_read option for db_stress
Summary: as title, also removed an incorrect assertion Test Plan: make check; db_stress --mmap_read=1; db_stress --mmap_read=0 Reviewers: dhruba, emayanke CC: leveldb Differential Revision: https://reviews.facebook.net/D11367
This commit is contained in:
parent
5ef6bb8c37
commit
96be2c4ee0
@ -427,7 +427,7 @@ struct Options {
|
|||||||
// Note: Deprecated
|
// Note: Deprecated
|
||||||
bool allow_readahead_compactions;
|
bool allow_readahead_compactions;
|
||||||
|
|
||||||
// Allow the OS to mmap file for reading. Default: false
|
// Allow the OS to mmap file for reading sst tables. Default: false
|
||||||
bool allow_mmap_reads;
|
bool allow_mmap_reads;
|
||||||
|
|
||||||
// Allow the OS to mmap file for writing. Default: true
|
// Allow the OS to mmap file for writing. Default: true
|
||||||
|
@ -110,6 +110,9 @@ static const char* FLAGS_db = nullptr;
|
|||||||
// Verify checksum for every block read from storage
|
// Verify checksum for every block read from storage
|
||||||
static bool FLAGS_verify_checksum = false;
|
static bool FLAGS_verify_checksum = false;
|
||||||
|
|
||||||
|
// Allow reads to occur via mmap-ing files
|
||||||
|
static bool FLAGS_use_mmap_reads = leveldb::EnvOptions().use_mmap_reads;
|
||||||
|
|
||||||
// Database statistics
|
// Database statistics
|
||||||
static std::shared_ptr<leveldb::Statistics> dbstats;
|
static std::shared_ptr<leveldb::Statistics> dbstats;
|
||||||
|
|
||||||
@ -934,6 +937,7 @@ class StressTest {
|
|||||||
options.env = FLAGS_env;
|
options.env = FLAGS_env;
|
||||||
options.disableDataSync = FLAGS_disable_data_sync;
|
options.disableDataSync = FLAGS_disable_data_sync;
|
||||||
options.use_fsync = FLAGS_use_fsync;
|
options.use_fsync = FLAGS_use_fsync;
|
||||||
|
options.allow_mmap_reads = FLAGS_use_mmap_reads;
|
||||||
leveldb_kill_odds = FLAGS_kill_random_test;
|
leveldb_kill_odds = FLAGS_kill_random_test;
|
||||||
options.target_file_size_base = FLAGS_target_file_size_base;
|
options.target_file_size_base = FLAGS_target_file_size_base;
|
||||||
options.target_file_size_multiplier = FLAGS_target_file_size_multiplier;
|
options.target_file_size_multiplier = FLAGS_target_file_size_multiplier;
|
||||||
@ -955,6 +959,9 @@ class StressTest {
|
|||||||
if (purge_percent.Uniform(100) < FLAGS_purge_redundant_percent - 1) {
|
if (purge_percent.Uniform(100) < FLAGS_purge_redundant_percent - 1) {
|
||||||
options.purge_redundant_kvs_while_flush = false;
|
options.purge_redundant_kvs_while_flush = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fprintf(stdout, "DB path: [%s]\n", FLAGS_db);
|
||||||
|
|
||||||
Status s;
|
Status s;
|
||||||
if (FLAGS_ttl == -1) {
|
if (FLAGS_ttl == -1) {
|
||||||
s = DB::Open(options, FLAGS_db, &db_);
|
s = DB::Open(options, FLAGS_db, &db_);
|
||||||
@ -1076,6 +1083,9 @@ int main(int argc, char** argv) {
|
|||||||
} else if (sscanf(argv[i], "--verify_checksum=%d%c", &n, &junk) == 1 &&
|
} else if (sscanf(argv[i], "--verify_checksum=%d%c", &n, &junk) == 1 &&
|
||||||
(n == 0 || n == 1)) {
|
(n == 0 || n == 1)) {
|
||||||
FLAGS_verify_checksum = n;
|
FLAGS_verify_checksum = n;
|
||||||
|
} else if (sscanf(argv[i], "--mmap_read=%d%c", &n, &junk) == 1 &&
|
||||||
|
(n == 0 || n == 1)) {
|
||||||
|
FLAGS_use_mmap_reads = n;
|
||||||
} else if (sscanf(argv[i], "--statistics=%d%c", &n, &junk) == 1 &&
|
} else if (sscanf(argv[i], "--statistics=%d%c", &n, &junk) == 1 &&
|
||||||
(n == 0 || n == 1)) {
|
(n == 0 || n == 1)) {
|
||||||
if (n == 1) {
|
if (n == 1) {
|
||||||
|
@ -108,7 +108,6 @@ class PosixSequentialFile: public SequentialFile {
|
|||||||
const EnvOptions& options)
|
const EnvOptions& options)
|
||||||
: filename_(fname), file_(f), fd_(fileno(f)),
|
: filename_(fname), file_(f), fd_(fileno(f)),
|
||||||
use_os_buffer_(options.use_os_buffer) {
|
use_os_buffer_(options.use_os_buffer) {
|
||||||
assert(!options.use_mmap_reads);
|
|
||||||
}
|
}
|
||||||
virtual ~PosixSequentialFile() { fclose(file_); }
|
virtual ~PosixSequentialFile() { fclose(file_); }
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user