aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/unified_agent_client/duration_counter.h
diff options
context:
space:
mode:
authorDaniil Cherednik <dan.cherednik@gmail.com>2023-03-31 10:54:08 +0300
committerDaniil Cherednik <dan.cherednik@gmail.com>2023-03-31 12:28:07 +0300
commitfc1cffcfa7f0497a1f97b384a24bcbf23362f3be (patch)
treec15f7ab5b9e9b20fd0ef8fc07d598d28e8b32004 /library/cpp/unified_agent_client/duration_counter.h
parent8a749596d40e91c896a1907afcd108d9221fbde1 (diff)
downloadydb-fc1cffcfa7f0497a1f97b384a24bcbf23362f3be.tar.gz
Ydb stable 23-1-1923.1.19
x-stable-origin-commit: c5d5a396e89d0a72e0267a55e93d8404d4fb54fe
Diffstat (limited to 'library/cpp/unified_agent_client/duration_counter.h')
-rw-r--r--library/cpp/unified_agent_client/duration_counter.h43
1 files changed, 43 insertions, 0 deletions
diff --git a/library/cpp/unified_agent_client/duration_counter.h b/library/cpp/unified_agent_client/duration_counter.h
new file mode 100644
index 0000000000..dbdfc22ed4
--- /dev/null
+++ b/library/cpp/unified_agent_client/duration_counter.h
@@ -0,0 +1,43 @@
+#pragma once
+
+#include <library/cpp/monlib/dynamic_counters/counters.h>
+
+#include <util/generic/deque.h>
+#include <util/system/hp_timer.h>
+#include <util/system/mutex.h>
+
+namespace NUnifiedAgent {
+ class TDurationUsCounter {
+ public:
+ class TScope {
+ public:
+ TScope(TDurationUsCounter& counter)
+ : Counter(counter)
+ , StartTime(Counter.Begin())
+ {
+ }
+
+ ~TScope() {
+ Counter.End(StartTime);
+ }
+
+ private:
+ TDurationUsCounter& Counter;
+ NHPTimer::STime* StartTime;
+ };
+
+ public:
+ TDurationUsCounter(const TString& name, NMonitoring::TDynamicCounters& owner);
+
+ NHPTimer::STime* Begin();
+
+ void End(NHPTimer::STime* startTime);
+
+ void Update();
+
+ private:
+ NMonitoring::TDeprecatedCounter& Counter;
+ TDeque<NHPTimer::STime> ActiveTimers;
+ TAdaptiveLock Lock;
+ };
+}