Skip to content

Commit f3e7189

Browse files
authored
[metric][improve]Histgram label expire (#857)
1 parent 712f1c7 commit f3e7189

File tree

3 files changed

+37
-8
lines changed

3 files changed

+37
-8
lines changed

include/ylt/metric/dynamic_metric.hpp

+10-8
Original file line numberDiff line numberDiff line change
@@ -92,6 +92,15 @@ class dynamic_metric_impl : public dynamic_metric {
9292
return map_.template copy<std::shared_ptr<metric_pair>>();
9393
}
9494

95+
void clean_expired_label() override {
96+
erase_if([now = std::chrono::steady_clock::now()](auto& pair) mutable {
97+
bool r = std::chrono::duration_cast<std::chrono::seconds>(
98+
now - pair.second->get_created_time())
99+
.count() >= ylt_label_max_age.count();
100+
return r;
101+
});
102+
}
103+
95104
protected:
96105
template <typename Key, typename... Args>
97106
std::pair<std::shared_ptr<metric_pair>, bool> try_emplace(Key&& key,
@@ -107,14 +116,7 @@ class dynamic_metric_impl : public dynamic_metric {
107116
},
108117
std::forward<Key>(key), std::forward<Args>(args)...);
109118
}
110-
void clean_expired_label() override {
111-
erase_if([now = std::chrono::steady_clock::now()](auto& pair) mutable {
112-
bool r = std::chrono::duration_cast<std::chrono::seconds>(
113-
now - pair.second->get_created_time())
114-
.count() >= ylt_label_max_age.count();
115-
return r;
116-
});
117-
}
119+
118120
std::shared_ptr<metric_pair> find(std::span<const std::string, N> key) const {
119121
return map_.find(key);
120122
}

include/ylt/metric/histogram.hpp

+9
Original file line numberDiff line numberDiff line change
@@ -188,6 +188,13 @@ class basic_dynamic_histogram : public dynamic_metric {
188188
bucket_counts_[bucket_index]->inc(labels_value);
189189
}
190190

191+
void clean_expired_label() override {
192+
sum_->clean_expired_label();
193+
for (auto &m : bucket_counts_) {
194+
m->clean_expired_label();
195+
}
196+
}
197+
191198
auto get_bucket_counts() { return bucket_counts_; }
192199

193200
bool has_label_value(const std::string &label_val) override {
@@ -202,6 +209,8 @@ class basic_dynamic_histogram : public dynamic_metric {
202209
return sum_->has_label_value(label_value);
203210
}
204211

212+
size_t label_value_count() const { return sum_->label_value_count(); }
213+
205214
void serialize(std::string &str) override {
206215
auto value_map = sum_->copy();
207216
if (value_map.empty()) {

src/metric/tests/test_metric.cpp

+18
Original file line numberDiff line numberDiff line change
@@ -1946,14 +1946,32 @@ TEST_CASE("test metric manager clean expired label") {
19461946
auto& inst = dynamic_metric_manager<test_tag>::instance();
19471947
auto pair = inst.create_metric_dynamic<dynamic_counter_1t>(
19481948
std::string("some_counter"), "", std::array<std::string, 1>{"url"});
1949+
auto summary = std::make_shared<basic_dynamic_summary<2>>(
1950+
std::string("test_summary"), std::string("summary help"),
1951+
std::vector<double>{0.5, 0.9, 0.95, 0.99},
1952+
std::array<std::string, 2>{"method", "url"});
1953+
auto h = std::make_shared<dynamic_histogram_t>(
1954+
std::string("test"), std::string("help"),
1955+
std::vector<double>{5.23, 10.54, 20.0, 50.0, 100.0},
1956+
std::array<std::string, 2>{"method", "url"});
1957+
inst.register_metric(summary);
1958+
inst.register_metric(h);
19491959
auto c = pair.second;
19501960
c->inc({"/"});
19511961
c->inc({"/test"});
1962+
summary->observe({"GET", "test"}, 10);
1963+
h->observe({"GET", "test"}, 10);
19521964
CHECK(c->label_value_count() == 2);
1965+
CHECK(summary->label_value_count() == 1);
1966+
CHECK(h->label_value_count() == 1);
19531967
std::this_thread::sleep_for(std::chrono::seconds(2));
19541968
c->inc({"/index"});
19551969
size_t count = c->label_value_count();
19561970
CHECK(count == 1);
1971+
auto ct1 = summary->label_value_count();
1972+
CHECK(ct1 == 0);
1973+
auto ct2 = h->label_value_count();
1974+
CHECK(ct2 == 0);
19571975
}
19581976

19591977
TEST_CASE("test remove label value") {

0 commit comments

Comments
 (0)