mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-16 12:44:42 +00:00
176 lines
4.9 KiB
C++
176 lines
4.9 KiB
C++
|
#include "TestStats.h"
|
||
|
namespace DB
|
||
|
{
|
||
|
|
||
|
namespace
|
||
|
{
|
||
|
const String FOUR_SPACES = " ";
|
||
|
}
|
||
|
|
||
|
String TestStats::getStatisticByName(const String & statistic_name)
|
||
|
{
|
||
|
if (statistic_name == "min_time")
|
||
|
return std::to_string(min_time) + "ms";
|
||
|
|
||
|
if (statistic_name == "quantiles")
|
||
|
{
|
||
|
String result = "\n";
|
||
|
|
||
|
for (double percent = 10; percent <= 90; percent += 10)
|
||
|
{
|
||
|
result += FOUR_SPACES + std::to_string((percent / 100));
|
||
|
result += ": " + std::to_string(sampler.quantileInterpolated(percent / 100.0));
|
||
|
result += "\n";
|
||
|
}
|
||
|
result += FOUR_SPACES + "0.95: " + std::to_string(sampler.quantileInterpolated(95 / 100.0)) + "\n";
|
||
|
result += FOUR_SPACES + "0.99: " + std::to_string(sampler.quantileInterpolated(99 / 100.0)) + "\n";
|
||
|
result += FOUR_SPACES + "0.999: " + std::to_string(sampler.quantileInterpolated(99.9 / 100.)) + "\n";
|
||
|
result += FOUR_SPACES + "0.9999: " + std::to_string(sampler.quantileInterpolated(99.99 / 100.));
|
||
|
|
||
|
return result;
|
||
|
}
|
||
|
if (statistic_name == "total_time")
|
||
|
return std::to_string(total_time) + "s";
|
||
|
|
||
|
if (statistic_name == "queries_per_second")
|
||
|
return std::to_string(queries / total_time);
|
||
|
|
||
|
if (statistic_name == "rows_per_second")
|
||
|
return std::to_string(total_rows_read / total_time);
|
||
|
|
||
|
if (statistic_name == "bytes_per_second")
|
||
|
return std::to_string(total_bytes_read / total_time);
|
||
|
|
||
|
if (statistic_name == "max_rows_per_second")
|
||
|
return std::to_string(max_rows_speed);
|
||
|
|
||
|
if (statistic_name == "max_bytes_per_second")
|
||
|
return std::to_string(max_bytes_speed);
|
||
|
|
||
|
if (statistic_name == "avg_rows_per_second")
|
||
|
return std::to_string(avg_rows_speed_value);
|
||
|
|
||
|
if (statistic_name == "avg_bytes_per_second")
|
||
|
return std::to_string(avg_bytes_speed_value);
|
||
|
|
||
|
return "";
|
||
|
}
|
||
|
|
||
|
|
||
|
void TestStats::update_min_time(UInt64 min_time_candidate)
|
||
|
{
|
||
|
if (min_time_candidate < min_time)
|
||
|
{
|
||
|
min_time = min_time_candidate;
|
||
|
min_time_watch.restart();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void TestStats::update_max_speed(
|
||
|
size_t max_speed_candidate,
|
||
|
Stopwatch & max_speed_watch,
|
||
|
double & max_speed)
|
||
|
{
|
||
|
if (max_speed_candidate > max_speed)
|
||
|
{
|
||
|
max_speed = max_speed_candidate;
|
||
|
max_speed_watch.restart();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
void TestStats::update_average_speed(
|
||
|
double new_speed_info,
|
||
|
Stopwatch & avg_speed_watch,
|
||
|
size_t & number_of_info_batches,
|
||
|
double precision,
|
||
|
double & avg_speed_first,
|
||
|
double & avg_speed_value)
|
||
|
{
|
||
|
avg_speed_value = ((avg_speed_value * number_of_info_batches) + new_speed_info);
|
||
|
++number_of_info_batches;
|
||
|
avg_speed_value /= number_of_info_batches;
|
||
|
|
||
|
if (avg_speed_first == 0)
|
||
|
{
|
||
|
avg_speed_first = avg_speed_value;
|
||
|
}
|
||
|
|
||
|
if (std::abs(avg_speed_value - avg_speed_first) >= precision)
|
||
|
{
|
||
|
avg_speed_first = avg_speed_value;
|
||
|
avg_speed_watch.restart();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void TestStats::add(size_t rows_read_inc, size_t bytes_read_inc)
|
||
|
{
|
||
|
total_rows_read += rows_read_inc;
|
||
|
total_bytes_read += bytes_read_inc;
|
||
|
last_query_rows_read += rows_read_inc;
|
||
|
last_query_bytes_read += bytes_read_inc;
|
||
|
|
||
|
double new_rows_speed = last_query_rows_read / watch_per_query.elapsedSeconds();
|
||
|
double new_bytes_speed = last_query_bytes_read / watch_per_query.elapsedSeconds();
|
||
|
|
||
|
/// Update rows speed
|
||
|
update_max_speed(new_rows_speed, max_rows_speed_watch, max_rows_speed);
|
||
|
update_average_speed(new_rows_speed,
|
||
|
avg_rows_speed_watch,
|
||
|
number_of_rows_speed_info_batches,
|
||
|
avg_rows_speed_precision,
|
||
|
avg_rows_speed_first,
|
||
|
avg_rows_speed_value);
|
||
|
/// Update bytes speed
|
||
|
update_max_speed(new_bytes_speed, max_bytes_speed_watch, max_bytes_speed);
|
||
|
update_average_speed(new_bytes_speed,
|
||
|
avg_bytes_speed_watch,
|
||
|
number_of_bytes_speed_info_batches,
|
||
|
avg_bytes_speed_precision,
|
||
|
avg_bytes_speed_first,
|
||
|
avg_bytes_speed_value);
|
||
|
}
|
||
|
|
||
|
void TestStats::updateQueryInfo()
|
||
|
{
|
||
|
++queries;
|
||
|
sampler.insert(watch_per_query.elapsedSeconds());
|
||
|
update_min_time(watch_per_query.elapsed() / (1000 * 1000)); /// ns to ms
|
||
|
}
|
||
|
|
||
|
void TestStats::clear()
|
||
|
{
|
||
|
watch.restart();
|
||
|
watch_per_query.restart();
|
||
|
min_time_watch.restart();
|
||
|
max_rows_speed_watch.restart();
|
||
|
max_bytes_speed_watch.restart();
|
||
|
avg_rows_speed_watch.restart();
|
||
|
avg_bytes_speed_watch.restart();
|
||
|
|
||
|
last_query_was_cancelled = false;
|
||
|
|
||
|
sampler.clear();
|
||
|
|
||
|
queries = 0;
|
||
|
total_rows_read = 0;
|
||
|
total_bytes_read = 0;
|
||
|
last_query_rows_read = 0;
|
||
|
last_query_bytes_read = 0;
|
||
|
|
||
|
min_time = std::numeric_limits<UInt64>::max();
|
||
|
total_time = 0;
|
||
|
max_rows_speed = 0;
|
||
|
max_bytes_speed = 0;
|
||
|
avg_rows_speed_value = 0;
|
||
|
avg_bytes_speed_value = 0;
|
||
|
avg_rows_speed_first = 0;
|
||
|
avg_bytes_speed_first = 0;
|
||
|
avg_rows_speed_precision = 0.001;
|
||
|
avg_bytes_speed_precision = 0.001;
|
||
|
number_of_rows_speed_info_batches = 0;
|
||
|
number_of_bytes_speed_info_batches = 0;
|
||
|
}
|
||
|
|
||
|
}
|