mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 10:22:10 +00:00
03e90cd7cf
The following metrics can be useful to calculate various rates (i.e. disk/network IO rates): - AsynchronousHeavyMetricsUpdateInterval - AsynchronousMetricsUpdateInterval The following had been added by analogy with the AsynchronousMetricsCalculationTimeSpent: - AsynchronousHeavyMetricsCalculationTimeSpent Signed-off-by: Azat Khuzhin <a.khuzhin@semrush.com>
39 lines
1.0 KiB
C++
39 lines
1.0 KiB
C++
#pragma once
|
|
|
|
#include <Common/AsynchronousMetrics.h>
|
|
#include <Interpreters/Context_fwd.h>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
|
|
class ServerAsynchronousMetrics : public AsynchronousMetrics, WithContext
|
|
{
|
|
public:
|
|
ServerAsynchronousMetrics(
|
|
ContextPtr global_context_,
|
|
int update_period_seconds,
|
|
int heavy_metrics_update_period_seconds,
|
|
const ProtocolServerMetricsFunc & protocol_server_metrics_func_);
|
|
private:
|
|
void updateImpl(AsynchronousMetricValues & new_values, TimePoint update_time, TimePoint current_time) override;
|
|
void logImpl(AsynchronousMetricValues & new_values) override;
|
|
|
|
const Duration heavy_metric_update_period;
|
|
TimePoint heavy_metric_previous_update_time;
|
|
double heavy_update_interval = 0.;
|
|
|
|
struct DetachedPartsStats
|
|
{
|
|
size_t count;
|
|
size_t detached_by_user;
|
|
};
|
|
|
|
DetachedPartsStats detached_parts_stats{};
|
|
|
|
void updateDetachedPartsStats();
|
|
void updateHeavyMetricsIfNeeded(TimePoint current_time, TimePoint update_time, AsynchronousMetricValues & new_values);
|
|
};
|
|
|
|
}
|