diff options
author | Daniil Cherednik <dan.cherednik@gmail.com> | 2023-03-31 10:54:08 +0300 |
---|---|---|
committer | Daniil Cherednik <dan.cherednik@gmail.com> | 2023-03-31 12:28:07 +0300 |
commit | fc1cffcfa7f0497a1f97b384a24bcbf23362f3be (patch) | |
tree | c15f7ab5b9e9b20fd0ef8fc07d598d28e8b32004 /library/cpp/unified_agent_client/duration_counter.h | |
parent | 8a749596d40e91c896a1907afcd108d9221fbde1 (diff) | |
download | ydb-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.h | 43 |
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; + }; +} |