diff --git a/src/meta/meta_backup_service.cpp b/src/meta/meta_backup_service.cpp index 451002f603..3947287ade 100644 --- a/src/meta/meta_backup_service.cpp +++ b/src/meta/meta_backup_service.cpp @@ -35,7 +35,6 @@ #include "meta/meta_state_service.h" #include "meta_backup_service.h" #include "meta_service.h" -#include "perf_counter/perf_counter.h" #include "runtime/api_layer1.h" #include "runtime/rpc/rpc_address.h" #include "runtime/rpc/rpc_holder.h" @@ -51,14 +50,47 @@ #include "utils/defer.h" #include "utils/flags.h" #include "utils/fmt_logging.h" +#include "utils/string_view.h" #include "utils/time_utils.h" +METRIC_DEFINE_entity(backup_policy); + +METRIC_DEFINE_gauge_int64(backup_policy, + policy_recent_backup_duration_ms, + dsn::metric_unit::kMilliSeconds, + "The recent backup duration"); + namespace dsn { namespace replication { DSN_DECLARE_int32(cold_backup_checkpoint_reserve_minutes); DSN_DECLARE_int32(fd_lease_seconds); +namespace { + +metric_entity_ptr instantiate_backup_policy_metric_entity(const std::string &policy_name) +{ + auto entity_id = fmt::format("backup_policy_{}", policy_name); + + return METRIC_ENTITY_backup_policy.instantiate(entity_id, {{"policy_name", policy_name}}); +} + +} // anonymous namespace + +backup_policy_metrics::backup_policy_metrics(const std::string &policy_name) + : _backup_policy_metric_entity(instantiate_backup_policy_metric_entity(policy_name)), + METRIC_VAR_INIT_backup_policy(policy_recent_backup_duration_ms) +{ +} + +const metric_entity_ptr &backup_policy_metrics::backup_policy_metric_entity() const +{ + CHECK_NOTNULL(_backup_policy_metric_entity, + "backup_policy metric entity should has been instantiated: " + "uninitialized entity cannot be used to instantiate metric"); + return _backup_policy_metric_entity; +} + // TODO: backup_service and policy_context should need two locks, its own _lock and server_state's // _lock this maybe lead to deadlock, should refactor this @@ -831,12 +863,8 @@ void policy_context::start() continue_current_backup_unlocked(); } - std::string counter_name = _policy.policy_name + ".recent.backup.duration(ms)"; - _counter_policy_recent_backup_duration_ms.init_app_counter( - "eon.meta.policy", - counter_name.c_str(), - COUNTER_TYPE_NUMBER, - "policy recent backup duration time"); + CHECK(!_policy.policy_name.empty(), "policy_name should has been initialized"); + _metrics = std::make_unique(_policy.policy_name); issue_gc_backup_info_task_unlocked(); LOG_INFO("{}: start gc backup info task succeed", _policy.policy_name); @@ -1012,7 +1040,7 @@ void policy_context::issue_gc_backup_info_task_unlocked() last_backup_duration_time_ms = (_cur_backup.end_time_ms - _cur_backup.start_time_ms); } } - _counter_policy_recent_backup_duration_ms->set(last_backup_duration_time_ms); + METRIC_SET(*_metrics, policy_recent_backup_duration_ms, last_backup_duration_time_ms); } void policy_context::sync_remove_backup_info(const backup_info &info, dsn::task_ptr sync_callback) @@ -1200,7 +1228,7 @@ error_code backup_service::sync_policies_from_remote_storage() std::shared_ptr policy_ctx = _factory(this); policy tpolicy; dsn::json::json_forwarder::decode(value, tpolicy); - policy_ctx->set_policy(std::move(tpolicy)); + policy_ctx->set_policy(tpolicy); { zauto_lock l(_lock); @@ -1337,7 +1365,7 @@ void backup_service::add_backup_policy(dsn::message_ex *msg) p.start_time.parse_from(request.start_time); p.app_ids = app_ids; p.app_names = app_names; - policy_context_ptr->set_policy(std::move(p)); + policy_context_ptr->set_policy(p); do_add_policy(msg, policy_context_ptr, response.hint_message); } diff --git a/src/meta/meta_backup_service.h b/src/meta/meta_backup_service.h index 3c7138cafb..639f010f37 100644 --- a/src/meta/meta_backup_service.h +++ b/src/meta/meta_backup_service.h @@ -37,12 +37,14 @@ #include "common/json_helper.h" #include "common/replication_other_types.h" #include "meta_rpc_types.h" -#include "perf_counter/perf_counter_wrapper.h" #include "runtime/task/task.h" #include "runtime/task/task_tracker.h" #include "utils/api_utilities.h" +#include "utils/autoref_ptr.h" #include "utils/error_code.h" #include "utils/fmt_utils.h" +#include "utils/metrics.h" +#include "utils/ports.h" #include "utils/zlocks.h" namespace dsn { @@ -176,6 +178,23 @@ struct backup_start_time DEFINE_JSON_SERIALIZATION(hour, minute) }; +class backup_policy_metrics +{ +public: + backup_policy_metrics() = default; + backup_policy_metrics(const std::string &policy_name); + + const metric_entity_ptr &backup_policy_metric_entity() const; + + METRIC_DEFINE_SET(policy_recent_backup_duration_ms, int64_t) + +private: + const metric_entity_ptr _backup_policy_metric_entity; + METRIC_VAR_DECLARE_gauge_int64(policy_recent_backup_duration_ms); + + DISALLOW_COPY_AND_ASSIGN(backup_policy_metrics); +}; + // // the backup process of meta server: // 1, write the app metadata to block filesystem @@ -196,6 +215,7 @@ class policy : public policy_info int32_t backup_history_count_to_keep; bool is_disable; backup_start_time start_time; + policy() : app_ids(), backup_interval_seconds(0), @@ -330,8 +350,9 @@ mock_private : backup_progress _progress; std::string _backup_sig; // policy_name@backup_id, used when print backup related log - perf_counter_wrapper _counter_policy_recent_backup_duration_ms; -//clang-format on + std::unique_ptr _metrics; + + //clang-format on dsn::task_tracker _tracker; }; diff --git a/src/meta/test/backup_test.cpp b/src/meta/test/backup_test.cpp index 9006e441da..b27ba49958 100644 --- a/src/meta/test/backup_test.cpp +++ b/src/meta/test/backup_test.cpp @@ -269,7 +269,7 @@ class policy_context_test : public meta_test_base _policy.app_names[4] = "app4"; _policy.app_names[6] = "app6"; _mp._backup_service = _service->_backup_handler.get(); - _mp.set_policy(policy(_policy)); + _mp.set_policy(_policy); _service->_storage ->create_node( diff --git a/src/utils/metrics.h b/src/utils/metrics.h index 244b234760..a14f15e9ca 100644 --- a/src/utils/metrics.h +++ b/src/utils/metrics.h @@ -169,6 +169,7 @@ class error_code; #define METRIC_VAR_INIT_disk(name, ...) METRIC_VAR_INIT(name, disk, ##__VA_ARGS__) #define METRIC_VAR_INIT_table(name, ...) METRIC_VAR_INIT(name, table, ##__VA_ARGS__) #define METRIC_VAR_INIT_partition(name, ...) METRIC_VAR_INIT(name, partition, ##__VA_ARGS__) +#define METRIC_VAR_INIT_backup_policy(name, ...) METRIC_VAR_INIT(name, backup_policy, ##__VA_ARGS__) // Perform increment-related operations on metrics including gauge and counter. #define METRIC_VAR_INCREMENT_BY(name, x) \