Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(bulkload): fix rocksDB parameter allow_ingest_behind lose after replica migration #1651

Merged
merged 12 commits into from
Nov 29, 2023
2 changes: 1 addition & 1 deletion src/client_lib/mutation.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
#include <vector>

#include "../base/pegasus_utils.h"
#include "utils/string_view.h"
#include "utils/enum_helper.h"

using namespace ::dsn;

Expand Down
32 changes: 25 additions & 7 deletions src/server/pegasus_server_impl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1667,8 +1667,8 @@ dsn::error_code pegasus_server_impl::start(int argc, char **argv)
// We don't use `loaded_data_cf_opts` directly because pointer-typed options will
// only be initialized with default values when calling 'LoadLatestOptions', see
// 'rocksdb/utilities/options_util.h'.
reset_rocksdb_options(loaded_data_cf_opts, &_table_data_cf_opts);
_db_opts.allow_ingest_behind = parse_allow_ingest_behind(envs);
reset_rocksdb_options(
loaded_data_cf_opts, loaded_db_opt, envs, &_table_data_cf_opts, &_db_opts);
}
} else {
// When create new DB, we have to create a new column family to store meta data (meta column
Expand Down Expand Up @@ -3133,8 +3133,11 @@ bool pegasus_server_impl::set_usage_scenario(const std::string &usage_scenario)
}
}

void pegasus_server_impl::reset_rocksdb_options(const rocksdb::ColumnFamilyOptions &base_opts,
rocksdb::ColumnFamilyOptions *target_opts)
void pegasus_server_impl::reset_rocksdb_options(const rocksdb::ColumnFamilyOptions &base_cf_opts,
const rocksdb::DBOptions &base_db_opt,
const std::map<std::string, std::string> &envs,
rocksdb::ColumnFamilyOptions *target_cf_opts,
rocksdb::DBOptions *target_db_opt)
{
LOG_INFO_PREFIX("Reset rocksdb envs options");
// Reset rocksdb option includes two aspects:
Expand All @@ -3143,11 +3146,13 @@ void pegasus_server_impl::reset_rocksdb_options(const rocksdb::ColumnFamilyOptio
// ROCKSDB_STATIC_OPTIONS

// aspect 1:
reset_usage_scenario_options(base_opts, target_opts);
reset_usage_scenario_options(base_cf_opts, target_cf_opts);

// aspect 2:
target_opts->num_levels = base_opts.num_levels;
target_opts->write_buffer_size = base_opts.write_buffer_size;
target_cf_opts->num_levels = base_cf_opts.num_levels;
target_cf_opts->write_buffer_size = base_cf_opts.write_buffer_size;

reset_allow_ingest_behind_option(base_db_opt, envs, target_db_opt);
}

void pegasus_server_impl::reset_usage_scenario_options(
Expand All @@ -3168,6 +3173,19 @@ void pegasus_server_impl::reset_usage_scenario_options(
target_opts->max_write_buffer_number = base_opts.max_write_buffer_number;
}

void pegasus_server_impl::reset_allow_ingest_behind_option(
const rocksdb::DBOptions &base_db_opt,
const std::map<std::string, std::string> &envs,
rocksdb::DBOptions *target_db_opt)
{
if (envs.empty()) {
// for reopen db during load balance learning
target_db_opt->allow_ingest_behind = base_db_opt.allow_ingest_behind;
} else {
target_db_opt->allow_ingest_behind = parse_allow_ingest_behind(envs);
}
ninsmiracle marked this conversation as resolved.
Show resolved Hide resolved
}

void pegasus_server_impl::recalculate_data_cf_options(
const rocksdb::ColumnFamilyOptions &cur_data_cf_opts)
{
Expand Down
11 changes: 9 additions & 2 deletions src/server/pegasus_server_impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -366,8 +366,15 @@ class pegasus_server_impl : public pegasus_read_service
void reset_usage_scenario_options(const rocksdb::ColumnFamilyOptions &base_opts,
rocksdb::ColumnFamilyOptions *target_opts);

void reset_rocksdb_options(const rocksdb::ColumnFamilyOptions &base_opts,
rocksdb::ColumnFamilyOptions *target_opts);
void reset_allow_ingest_behind_option(const rocksdb::DBOptions &base_db_opt,
acelyc111 marked this conversation as resolved.
Show resolved Hide resolved
const std::map<std::string, std::string> &envs,
rocksdb::DBOptions *target_db_opt);

void reset_rocksdb_options(const rocksdb::ColumnFamilyOptions &base_cf_opts,
const rocksdb::DBOptions &base_db_opt,
const std::map<std::string, std::string> &envs,
rocksdb::ColumnFamilyOptions *target_cf_opts,
rocksdb::DBOptions *target_db_opt);

// return true if successfully set
bool set_options(const std::unordered_map<std::string, std::string> &new_options);
Expand Down
Loading