Skip to content

Commit

Permalink
Reply to empiredan's suggestion and modify my code.
Browse files Browse the repository at this point in the history
  • Loading branch information
ruojieranyishen committed Jul 11, 2023
1 parent 4b838e2 commit 5c90ad5
Show file tree
Hide file tree
Showing 6 changed files with 57 additions and 10 deletions.
10 changes: 6 additions & 4 deletions src/base/pegasus_const.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -124,28 +124,30 @@ const std::unordered_map<std::string, cf_opts_setter> cf_opts_setters = {
{ROCKSDB_WRITE_BUFFER_SIZE,
[](const std::string &str, rocksdb::ColumnFamilyOptions &option) -> bool {
uint64_t val = 0;
if (!dsn::buf2uint64(str, val))
if (!dsn::buf2uint64(str, val)) {
return false;
}
option.write_buffer_size = static_cast<size_t>(val);
return true;
}},
{ROCKSDB_NUM_LEVELS,
[](const std::string &str, rocksdb::ColumnFamilyOptions &option) -> bool {
int32_t val = 0;
if (!dsn::buf2int32(str, val))
if (!dsn::buf2int32(str, val)) {
return false;
}
option.num_levels = val;
return true;
}},
};

const std::unordered_map<std::string, cf_opts_getter> cf_opts_getters = {
{ROCKSDB_WRITE_BUFFER_SIZE,
[](/*out*/ std::string &str, const rocksdb::ColumnFamilyOptions &option) {
[](const rocksdb::ColumnFamilyOptions &option, /*out*/ std::string &str) {
str = fmt::format("{}", option.write_buffer_size);
}},
{ROCKSDB_NUM_LEVELS,
[](/*out*/ std::string &str, const rocksdb::ColumnFamilyOptions &option) {
[](const rocksdb::ColumnFamilyOptions &option, /*out*/ std::string &str) {
str = fmt::format("{}", option.num_levels);
}},
};
Expand Down
2 changes: 1 addition & 1 deletion src/base/pegasus_const.h
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,6 @@ using cf_opts_setter = std::function<bool(const std::string &, rocksdb::ColumnFa
extern const std::unordered_map<std::string, cf_opts_setter> cf_opts_setters;

using cf_opts_getter =
std::function<void(/*out*/ std::string &, const rocksdb::ColumnFamilyOptions &)>;
std::function<void(const rocksdb::ColumnFamilyOptions &, /*out*/ std::string &)>;
extern const std::unordered_map<std::string, cf_opts_getter> cf_opts_getters;
} // namespace pegasus
2 changes: 1 addition & 1 deletion src/meta/test/meta_app_envs_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -209,7 +209,7 @@ TEST_F(meta_app_envs_test, update_app_envs_test)
// Make sure all rocksdb options of ROCKSDB_DYNAMIC_OPTIONS are tested.
// Hint: Mainly verify the update_rocksdb_dynamic_options function.
std::map<std::string, std::string> all_test_envs;
for (auto test : tests) {
for (const auto &test : tests) {
all_test_envs[test.env_key] = test.env_value;
}
for (const auto &option : replica_envs::ROCKSDB_DYNAMIC_OPTIONS) {
Expand Down
24 changes: 23 additions & 1 deletion src/meta/test/meta_app_operation_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -367,9 +367,11 @@ TEST_F(meta_app_operation_test, create_app)
// - create succeed with success_if_exist=true
// - wrong rocksdb.num_levels (< 1)
// - wrong rocksdb.num_levels (> 10)
// - wrong rocksdb.num_levels (non-digital character)
// - create app with rocksdb.num_levels (= 5) succeed
// - wrong rocksdb.write_buffer_size (< (16<<20))
// - wrong rocksdb.write_buffer_size (> (512<<20))
// - wrong rocksdb.write_buffer_size (non-digital character)
// - create app with rocksdb.write_buffer_size (= (32<<20)) succeed
struct create_test
{
Expand Down Expand Up @@ -441,6 +443,16 @@ TEST_F(meta_app_operation_test, create_app)
app_status::AS_INVALID,
ERR_INVALID_PARAMETERS,
{{"rocksdb.num_levels", "11"}}},
{APP_NAME + "_11",
4,
3,
2,
3,
3,
false,
app_status::AS_INVALID,
ERR_INVALID_PARAMETERS,
{{"rocksdb.num_levels", "5i"}}},
{APP_NAME + "_11",
4,
3,
Expand Down Expand Up @@ -471,6 +483,16 @@ TEST_F(meta_app_operation_test, create_app)
app_status::AS_INVALID,
ERR_INVALID_PARAMETERS,
{{"rocksdb.write_buffer_size", "1073741824"}}},
{APP_NAME,
4,
3,
2,
3,
3,
false,
app_status::AS_INVALID,
ERR_INVALID_PARAMETERS,
{{"rocksdb.write_buffer_size", "n33554432"}}},
{APP_NAME + "_12",
4,
3,
Expand Down Expand Up @@ -539,7 +561,7 @@ TEST_F(meta_app_operation_test, create_app)
// Make sure all rocksdb options of ROCKSDB_DYNAMIC_OPTIONS and ROCKSDB_STATIC_OPTIONS are
// tested. Hint: Mainly verify the validate_app_envs function.
std::map<std::string, std::string> all_test_envs;
for (auto test : tests) {
for (const auto &test : tests) {
all_test_envs.insert(test.envs.begin(), test.envs.end());
}
for (const auto &option : replica_envs::ROCKSDB_DYNAMIC_OPTIONS) {
Expand Down
25 changes: 24 additions & 1 deletion src/server/pegasus_server_impl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2644,6 +2644,7 @@ void pegasus_server_impl::update_rocksdb_dynamic_options(
std::vector<std::string> args;
// split_args example: Parse "write_buffer_size" from "rocksdb.write_buffer_size"
dsn::utils::split_args(option.c_str(), args, '.');
CHECK_EQ(args.size(), 2);
new_options[args[1]] = find->second;
}

Expand Down Expand Up @@ -2732,7 +2733,29 @@ void pegasus_server_impl::query_app_envs(/*out*/ std::map<std::string, std::stri
// Get Data ColumnFamilyOptions directly from _data_cf
rocksdb::ColumnFamilyDescriptor desc;
rocksdb::Status s = _data_cf->GetDescriptor(&desc);
envs[ROCKSDB_NUM_LEVELS] = fmt::format("{}", desc.options.num_levels);
for (const auto &option : pegasus::ROCKSDB_STATIC_OPTIONS) {
auto getter = cf_opts_getters.find(option);
if (getter == cf_opts_getters.end()) {
LOG_WARNING("cannot find {} getter function, and get this option fail.", option);
continue;
}
std::string option_val;
getter->second(desc.options, option_val);
envs[option] = option_val;
}
for (const auto &option : pegasus::ROCKSDB_DYNAMIC_OPTIONS) {
if (option.compare(ROCKSDB_WRITE_BUFFER_SIZE)) {
continue;
}
auto getter = cf_opts_getters.find(option);
if (getter == cf_opts_getters.end()) {
LOG_WARNING("cannot find {} getter function, and get this option fail.", option);
continue;
}
std::string option_val;
getter->second(desc.options, option_val);
envs[option] = option_val;
}
}

void pegasus_server_impl::update_usage_scenario(const std::map<std::string, std::string> &envs)
Expand Down
4 changes: 2 additions & 2 deletions src/server/test/pegasus_server_impl_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ class pegasus_server_impl_test : public pegasus_server_test_base
{
// Make sure all rocksdb options of ROCKSDB_DYNAMIC_OPTIONS and ROCKSDB_STATIC_OPTIONS
// are tested.
for (auto test : tests) {
for (const auto &test : tests) {
all_test_envs[test.env_key] = test.env_value;
}
for (const auto &option : pegasus::ROCKSDB_DYNAMIC_OPTIONS) {
Expand All @@ -132,7 +132,7 @@ class pegasus_server_impl_test : public pegasus_server_test_base

std::map<std::string, std::string> query_envs;
_server->query_app_envs(query_envs);
for (auto test : tests) {
for (const auto &test : tests) {
auto iter = query_envs.find(test.env_key);
if (iter != query_envs.end()) {
ASSERT_EQ(iter->second, test.expect_value);
Expand Down

0 comments on commit 5c90ad5

Please sign in to comment.