Commit a20c6032 authored by John Esmet's avatar John Esmet Committed by Yoni Fogel

fixes #5912 compression types are now passed through the command line


git-svn-id: file:///svn/toku/tokudb@52294 c7de825b-a66e-492c-adef-691d508d4ae1
parent 24c83d48
...@@ -105,12 +105,12 @@ struct cli_args { ...@@ -105,12 +105,12 @@ struct cli_args {
bool print_thread_performance; bool print_thread_performance;
bool print_iteration_performance; bool print_iteration_performance;
enum perf_output_format perf_output_format; enum perf_output_format perf_output_format;
enum toku_compression_method compression_method; // the compression method to use on newly created DBs
int performance_period; int performance_period;
uint32_t txn_size; // specifies number of updates/puts/whatevers per txn uint32_t txn_size; // specifies number of updates/puts/whatevers per txn
uint32_t key_size; // number of bytes in vals. Must be at least 4 uint32_t key_size; // number of bytes in vals. Must be at least 4
uint32_t val_size; // number of bytes in vals. Must be at least 4 uint32_t val_size; // number of bytes in vals. Must be at least 4
double compressibility; // how much of each key/val (as a fraction in [0,1]) can be compressed away double compressibility; // the row values should compress down to this fraction
// First 4-8 bytes of key may be ignored
struct env_args env_args; // specifies environment variables struct env_args env_args; // specifies environment variables
bool single_txn; bool single_txn;
bool warm_cache; // warm caches before running stress_table bool warm_cache; // warm caches before running stress_table
...@@ -1659,6 +1659,8 @@ static int create_tables(DB_ENV **env_res, DB **db_res, int num_DBs, ...@@ -1659,6 +1659,8 @@ static int create_tables(DB_ENV **env_res, DB **db_res, int num_DBs,
CKERR(r); CKERR(r);
r = db->set_readpagesize(db, env_args.basement_node_size); r = db->set_readpagesize(db, env_args.basement_node_size);
CKERR(r); CKERR(r);
r = db->set_compression_method(db, cli_args->compression_method);
CKERR(r);
const int flags = DB_CREATE | (cli_args->blackhole ? DB_BLACKHOLE : 0); const int flags = DB_CREATE | (cli_args->blackhole ? DB_BLACKHOLE : 0);
r = db->open(db, null_txn, name, nullptr, DB_BTREE, flags, 0666); r = db->open(db, null_txn, name, nullptr, DB_BTREE, flags, 0666);
CKERR(r); CKERR(r);
...@@ -1928,6 +1930,7 @@ static struct cli_args UU() get_default_args(void) { ...@@ -1928,6 +1930,7 @@ static struct cli_args UU() get_default_args(void) {
.print_thread_performance = true, .print_thread_performance = true,
.print_iteration_performance = true, .print_iteration_performance = true,
.perf_output_format = HUMAN, .perf_output_format = HUMAN,
.compression_method = TOKU_DEFAULT_COMPRESSION_METHOD,
.performance_period = 1, .performance_period = 1,
.txn_size = 1000, .txn_size = 1000,
.key_size = min_key_size, .key_size = min_key_size,
...@@ -2277,6 +2280,7 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct ...@@ -2277,6 +2280,7 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct
MAKE_LOCAL_ARG(name_string, type_string, s, default, variable, "", "", "") MAKE_LOCAL_ARG(name_string, type_string, s, default, variable, "", "", "")
const char *perf_format_s = nullptr; const char *perf_format_s = nullptr;
const char *compression_method_s = nullptr;
struct arg_type arg_types[] = { struct arg_type arg_types[] = {
INT32_ARG_NONNEG("--num_elements", num_elements, ""), INT32_ARG_NONNEG("--num_elements", num_elements, ""),
INT32_ARG_NONNEG("--num_DBs", num_DBs, ""), INT32_ARG_NONNEG("--num_DBs", num_DBs, ""),
...@@ -2334,7 +2338,8 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct ...@@ -2334,7 +2338,8 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct
STRING_ARG("--envdir", env_args.envdir), STRING_ARG("--envdir", env_args.envdir),
LOCAL_STRING_ARG("--perf_format", perf_format_s, "human"), LOCAL_STRING_ARG("--perf_format", perf_format_s, "human"),
LOCAL_STRING_ARG("--compression_method", compression_method_s, "quicklz"),
//TODO(add --quiet, -v, -h) //TODO(add --quiet, -v, -h)
}; };
#undef UINT32_ARG #undef UINT32_ARG
...@@ -2389,6 +2394,21 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct ...@@ -2389,6 +2394,21 @@ static inline void parse_stress_test_args (int argc, char *const argv[], struct
} }
} }
} }
if (compression_method_s != nullptr) {
if (strcmp(compression_method_s, "quicklz") == 0) {
args->compression_method = TOKU_QUICKLZ_METHOD;
} else if (strcmp(compression_method_s, "zlib") == 0) {
args->compression_method = TOKU_ZLIB_METHOD;
} else if (strcmp(compression_method_s, "lzma") == 0) {
args->compression_method = TOKU_LZMA_METHOD;
} else if (strcmp(compression_method_s, "none") == 0) {
args->compression_method = TOKU_NO_COMPRESSION;
} else {
fprintf(stderr, "valid values for --compression_method are \"quicklz\", \"zlib\", \"lzma\" and \"none\"\n");
do_usage(argv0, num_arg_types, arg_types);
exit(EINVAL);
}
}
if (perf_format_s != nullptr) { if (perf_format_s != nullptr) {
if (!strcmp(perf_format_s, "human")) { if (!strcmp(perf_format_s, "human")) {
args->perf_output_format = HUMAN; args->perf_output_format = HUMAN;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment