2022-08-02 10:45:06 +00:00
|
|
|
#include <Interpreters/QueryLog.h>
|
|
|
|
|
2018-06-20 17:49:52 +00:00
|
|
|
#include <Columns/ColumnArray.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <Columns/ColumnFixedString.h>
|
|
|
|
#include <Columns/ColumnString.h>
|
|
|
|
#include <Columns/ColumnsNumber.h>
|
2018-05-17 16:01:41 +00:00
|
|
|
#include <DataTypes/DataTypeArray.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <DataTypes/DataTypeDateTime64.h>
|
|
|
|
#include <DataTypes/DataTypeDate.h>
|
|
|
|
#include <DataTypes/DataTypeNullable.h>
|
|
|
|
#include <DataTypes/DataTypeDateTime.h>
|
2019-08-01 11:11:08 +00:00
|
|
|
#include <DataTypes/DataTypeEnum.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <DataTypes/DataTypeFactory.h>
|
2021-01-05 10:10:19 +00:00
|
|
|
#include <DataTypes/DataTypeMap.h>
|
2020-12-12 05:57:27 +00:00
|
|
|
#include <DataTypes/DataTypeLowCardinality.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <DataTypes/DataTypeString.h>
|
2022-08-13 13:03:16 +00:00
|
|
|
#include <DataTypes/DataTypeUUID.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <DataTypes/DataTypesNumber.h>
|
2018-06-20 17:49:52 +00:00
|
|
|
#include <Interpreters/ProfileEventsExt.h>
|
2020-08-18 21:41:01 +00:00
|
|
|
#include <Common/ClickHouseRevision.h>
|
|
|
|
#include <Common/IPv6ToBinary.h>
|
|
|
|
#include <Common/ProfileEvents.h>
|
2021-01-05 10:10:19 +00:00
|
|
|
#include <Common/typeid_cast.h>
|
2015-06-26 19:23:25 +00:00
|
|
|
|
2022-08-02 10:45:06 +00:00
|
|
|
#include <Poco/Net/IPAddress.h>
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
|
2015-06-26 19:23:25 +00:00
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
2020-09-04 16:47:02 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
NamesAndTypesList QueryLogElement::getNamesAndTypes()
|
2015-06-26 19:23:25 +00:00
|
|
|
{
|
2020-09-04 16:10:29 +00:00
|
|
|
auto query_status_datatype = std::make_shared<DataTypeEnum8>(
|
|
|
|
DataTypeEnum8::Values
|
2020-09-04 16:47:02 +00:00
|
|
|
{
|
|
|
|
{"QueryStart", static_cast<Int8>(QUERY_START)},
|
|
|
|
{"QueryFinish", static_cast<Int8>(QUERY_FINISH)},
|
|
|
|
{"ExceptionBeforeStart", static_cast<Int8>(EXCEPTION_BEFORE_START)},
|
|
|
|
{"ExceptionWhileProcessing", static_cast<Int8>(EXCEPTION_WHILE_PROCESSING)}
|
|
|
|
});
|
2020-08-18 21:41:01 +00:00
|
|
|
|
2020-09-04 16:10:29 +00:00
|
|
|
return
|
|
|
|
{
|
2021-06-28 11:42:21 +00:00
|
|
|
{"type", std::move(query_status_datatype)},
|
|
|
|
{"event_date", std::make_shared<DataTypeDate>()},
|
|
|
|
{"event_time", std::make_shared<DataTypeDateTime>()},
|
|
|
|
{"event_time_microseconds", std::make_shared<DataTypeDateTime64>(6)},
|
|
|
|
{"query_start_time", std::make_shared<DataTypeDateTime>()},
|
|
|
|
{"query_start_time_microseconds", std::make_shared<DataTypeDateTime64>(6)},
|
|
|
|
{"query_duration_ms", std::make_shared<DataTypeUInt64>()},
|
2021-01-05 10:10:19 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"read_rows", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"read_bytes", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"written_rows", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"written_bytes", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"result_rows", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"result_bytes", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"memory_usage", std::make_shared<DataTypeUInt64>()},
|
2021-01-05 10:10:19 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"current_database", std::make_shared<DataTypeString>()},
|
|
|
|
{"query", std::make_shared<DataTypeString>()},
|
2021-08-07 06:26:08 +00:00
|
|
|
{"formatted_query", std::make_shared<DataTypeString>()},
|
2021-06-28 11:42:21 +00:00
|
|
|
{"normalized_query_hash", std::make_shared<DataTypeUInt64>()},
|
|
|
|
{"query_kind", std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>())},
|
|
|
|
{"databases", std::make_shared<DataTypeArray>(
|
|
|
|
std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
|
|
|
{"tables", std::make_shared<DataTypeArray>(
|
|
|
|
std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
|
|
|
{"columns", std::make_shared<DataTypeArray>(
|
|
|
|
std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
|
|
|
{"projections", std::make_shared<DataTypeArray>(
|
|
|
|
std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
2021-06-24 16:54:04 +00:00
|
|
|
{"views", std::make_shared<DataTypeArray>(
|
|
|
|
std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
2021-06-28 11:42:21 +00:00
|
|
|
{"exception_code", std::make_shared<DataTypeInt32>()},
|
|
|
|
{"exception", std::make_shared<DataTypeString>()},
|
|
|
|
{"stack_trace", std::make_shared<DataTypeString>()},
|
2020-08-18 21:41:01 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"is_initial_query", std::make_shared<DataTypeUInt8>()},
|
|
|
|
{"user", std::make_shared<DataTypeString>()},
|
|
|
|
{"query_id", std::make_shared<DataTypeString>()},
|
|
|
|
{"address", DataTypeFactory::instance().get("IPv6")},
|
|
|
|
{"port", std::make_shared<DataTypeUInt16>()},
|
|
|
|
{"initial_user", std::make_shared<DataTypeString>()},
|
|
|
|
{"initial_query_id", std::make_shared<DataTypeString>()},
|
|
|
|
{"initial_address", DataTypeFactory::instance().get("IPv6")},
|
|
|
|
{"initial_port", std::make_shared<DataTypeUInt16>()},
|
|
|
|
{"initial_query_start_time", std::make_shared<DataTypeDateTime>()},
|
|
|
|
{"initial_query_start_time_microseconds", std::make_shared<DataTypeDateTime64>(6)},
|
|
|
|
{"interface", std::make_shared<DataTypeUInt8>()},
|
2022-03-28 08:30:34 +00:00
|
|
|
{"is_secure", std::make_shared<DataTypeUInt8>()},
|
2021-06-28 11:42:21 +00:00
|
|
|
{"os_user", std::make_shared<DataTypeString>()},
|
|
|
|
{"client_hostname", std::make_shared<DataTypeString>()},
|
|
|
|
{"client_name", std::make_shared<DataTypeString>()},
|
|
|
|
{"client_revision", std::make_shared<DataTypeUInt32>()},
|
|
|
|
{"client_version_major", std::make_shared<DataTypeUInt32>()},
|
|
|
|
{"client_version_minor", std::make_shared<DataTypeUInt32>()},
|
|
|
|
{"client_version_patch", std::make_shared<DataTypeUInt32>()},
|
|
|
|
{"http_method", std::make_shared<DataTypeUInt8>()},
|
|
|
|
{"http_user_agent", std::make_shared<DataTypeString>()},
|
|
|
|
{"http_referer", std::make_shared<DataTypeString>()},
|
|
|
|
{"forwarded_for", std::make_shared<DataTypeString>()},
|
|
|
|
{"quota_key", std::make_shared<DataTypeString>()},
|
2022-03-11 09:57:34 +00:00
|
|
|
{"distributed_depth", std::make_shared<DataTypeUInt64>()},
|
2020-08-18 21:41:01 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"revision", std::make_shared<DataTypeUInt32>()},
|
2018-08-14 20:29:42 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"log_comment", std::make_shared<DataTypeString>()},
|
2021-01-25 19:18:23 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"thread_ids", std::make_shared<DataTypeArray>(std::make_shared<DataTypeUInt64>())},
|
|
|
|
{"ProfileEvents", std::make_shared<DataTypeMap>(std::make_shared<DataTypeString>(), std::make_shared<DataTypeUInt64>())},
|
|
|
|
{"Settings", std::make_shared<DataTypeMap>(std::make_shared<DataTypeString>(), std::make_shared<DataTypeString>())},
|
2021-01-20 10:54:11 +00:00
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
{"used_aggregate_functions", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_aggregate_function_combinators", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_database_engines", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_data_type_families", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_dictionaries", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_formats", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_functions", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
|
|
|
{"used_storages", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
2021-07-28 19:21:48 +00:00
|
|
|
{"used_table_functions", std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())},
|
2022-10-20 07:46:16 +00:00
|
|
|
|
2022-10-21 16:13:36 +00:00
|
|
|
{"used_row_policies", std::make_shared<DataTypeArray>(std::make_shared<DataTypeLowCardinality>(std::make_shared<DataTypeString>()))},
|
2021-07-28 19:21:48 +00:00
|
|
|
|
2021-11-08 18:56:09 +00:00
|
|
|
{"transaction_id", getTransactionIDDataType()},
|
2020-09-04 16:10:29 +00:00
|
|
|
};
|
|
|
|
|
2015-06-26 19:23:25 +00:00
|
|
|
}
|
|
|
|
|
2021-06-28 11:42:21 +00:00
|
|
|
NamesAndAliases QueryLogElement::getNamesAndAliases()
|
|
|
|
{
|
|
|
|
return
|
|
|
|
{
|
|
|
|
{"ProfileEvents.Names", {std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())}, "mapKeys(ProfileEvents)"},
|
|
|
|
{"ProfileEvents.Values", {std::make_shared<DataTypeArray>(std::make_shared<DataTypeUInt64>())}, "mapValues(ProfileEvents)"},
|
|
|
|
{"Settings.Names", {std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())}, "mapKeys(Settings)" },
|
|
|
|
{"Settings.Values", {std::make_shared<DataTypeArray>(std::make_shared<DataTypeString>())}, "mapValues(Settings)"}
|
|
|
|
};
|
|
|
|
}
|
2015-06-26 19:23:25 +00:00
|
|
|
|
2020-05-21 20:15:18 +00:00
|
|
|
void QueryLogElement::appendToBlock(MutableColumns & columns) const
|
2015-06-26 19:23:25 +00:00
|
|
|
{
|
2017-04-01 07:20:54 +00:00
|
|
|
size_t i = 0;
|
2016-10-24 21:40:39 +00:00
|
|
|
|
2019-08-01 11:11:08 +00:00
|
|
|
columns[i++]->insert(type);
|
2020-04-17 13:26:44 +00:00
|
|
|
columns[i++]->insert(DateLUT::instance().toDayNum(event_time).toUnderType());
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(event_time);
|
2020-09-11 16:51:24 +00:00
|
|
|
columns[i++]->insert(event_time_microseconds);
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(query_start_time);
|
2020-08-18 21:41:01 +00:00
|
|
|
columns[i++]->insert(query_start_time_microseconds);
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(query_duration_ms);
|
2017-12-15 18:23:05 +00:00
|
|
|
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(read_rows);
|
|
|
|
columns[i++]->insert(read_bytes);
|
|
|
|
columns[i++]->insert(written_rows);
|
|
|
|
columns[i++]->insert(written_bytes);
|
|
|
|
columns[i++]->insert(result_rows);
|
|
|
|
columns[i++]->insert(result_bytes);
|
2016-12-06 20:55:13 +00:00
|
|
|
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(memory_usage);
|
2015-07-01 05:18:54 +00:00
|
|
|
|
2020-07-22 04:00:16 +00:00
|
|
|
columns[i++]->insertData(current_database.data(), current_database.size());
|
2017-12-15 18:23:05 +00:00
|
|
|
columns[i++]->insertData(query.data(), query.size());
|
2021-08-07 06:26:08 +00:00
|
|
|
columns[i++]->insertData(formatted_query.data(), formatted_query.size());
|
2020-12-02 12:08:03 +00:00
|
|
|
columns[i++]->insert(normalized_query_hash);
|
|
|
|
columns[i++]->insertData(query_kind.data(), query_kind.size());
|
|
|
|
|
|
|
|
{
|
|
|
|
auto & column_databases = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_tables = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_columns = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-02-10 14:12:49 +00:00
|
|
|
auto & column_projections = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-06-24 16:54:04 +00:00
|
|
|
auto & column_views = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-01-22 09:02:58 +00:00
|
|
|
|
2020-12-02 12:08:03 +00:00
|
|
|
auto fill_column = [](const std::set<String> & data, ColumnArray & column)
|
|
|
|
{
|
|
|
|
size_t size = 0;
|
|
|
|
for (const auto & name : data)
|
|
|
|
{
|
|
|
|
column.getData().insertData(name.data(), name.size());
|
|
|
|
++size;
|
|
|
|
}
|
|
|
|
auto & offsets = column.getOffsets();
|
|
|
|
offsets.push_back(offsets.back() + size);
|
|
|
|
};
|
2021-01-21 21:15:11 +00:00
|
|
|
|
2020-12-02 12:08:03 +00:00
|
|
|
fill_column(query_databases, column_databases);
|
|
|
|
fill_column(query_tables, column_tables);
|
|
|
|
fill_column(query_columns, column_columns);
|
2021-02-10 14:12:49 +00:00
|
|
|
fill_column(query_projections, column_projections);
|
2021-06-24 16:54:04 +00:00
|
|
|
fill_column(query_views, column_views);
|
2020-12-02 12:08:03 +00:00
|
|
|
}
|
|
|
|
|
2020-01-21 19:49:42 +00:00
|
|
|
columns[i++]->insert(exception_code);
|
2020-01-22 12:29:30 +00:00
|
|
|
columns[i++]->insertData(exception.data(), exception.size());
|
2017-12-15 18:23:05 +00:00
|
|
|
columns[i++]->insertData(stack_trace.data(), stack_trace.size());
|
2015-07-01 05:18:54 +00:00
|
|
|
|
2018-05-31 15:54:08 +00:00
|
|
|
appendClientInfo(client_info, columns, i);
|
2015-06-26 19:23:25 +00:00
|
|
|
|
2020-09-17 12:15:05 +00:00
|
|
|
columns[i++]->insert(ClickHouseRevision::getVersionRevision());
|
2016-11-16 05:09:41 +00:00
|
|
|
|
2021-01-25 19:18:23 +00:00
|
|
|
columns[i++]->insertData(log_comment.data(), log_comment.size());
|
|
|
|
|
2018-05-17 16:01:41 +00:00
|
|
|
{
|
|
|
|
Array threads_array;
|
2020-02-02 02:27:15 +00:00
|
|
|
threads_array.reserve(thread_ids.size());
|
2020-02-02 20:01:13 +00:00
|
|
|
for (const UInt64 thread_id : thread_ids)
|
|
|
|
threads_array.emplace_back(thread_id);
|
2019-08-31 21:47:15 +00:00
|
|
|
columns[i++]->insert(threads_array);
|
2018-05-17 16:01:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (profile_counters)
|
|
|
|
{
|
2021-01-05 10:10:19 +00:00
|
|
|
auto * column = columns[i++].get();
|
|
|
|
ProfileEvents::dumpToMapColumn(*profile_counters, column, true);
|
2018-05-17 16:01:41 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
columns[i++]->insertDefault();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (query_settings)
|
|
|
|
{
|
2021-01-05 10:10:19 +00:00
|
|
|
auto * column = columns[i++].get();
|
|
|
|
query_settings->dumpToMapColumn(column, true);
|
2018-05-17 16:01:41 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
columns[i++]->insertDefault();
|
|
|
|
}
|
2021-01-20 10:54:11 +00:00
|
|
|
|
2021-01-21 21:15:11 +00:00
|
|
|
{
|
2021-01-22 09:02:58 +00:00
|
|
|
auto & column_aggregate_function_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-01-23 12:07:37 +00:00
|
|
|
auto & column_aggregate_function_combinator_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-01-22 09:02:58 +00:00
|
|
|
auto & column_database_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_data_type_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_dictionary_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_format_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_function_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_storage_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
|
|
|
auto & column_table_function_factory_objects = typeid_cast<ColumnArray &>(*columns[i++]);
|
2022-08-02 10:45:06 +00:00
|
|
|
auto & column_row_policies_names = typeid_cast<ColumnArray &>(*columns[i++]);
|
2021-01-22 09:02:58 +00:00
|
|
|
|
2022-08-02 10:45:06 +00:00
|
|
|
auto fill_column = [](const auto & data, ColumnArray & column)
|
2021-01-21 21:15:11 +00:00
|
|
|
{
|
|
|
|
size_t size = 0;
|
2022-08-02 10:45:06 +00:00
|
|
|
for (const auto & value : data)
|
2021-01-21 21:15:11 +00:00
|
|
|
{
|
2022-08-02 10:45:06 +00:00
|
|
|
column.getData().insert(value);
|
2021-01-21 21:15:11 +00:00
|
|
|
++size;
|
|
|
|
}
|
|
|
|
auto & offsets = column.getOffsets();
|
|
|
|
offsets.push_back(offsets.back() + size);
|
|
|
|
};
|
|
|
|
|
|
|
|
fill_column(used_aggregate_functions, column_aggregate_function_factory_objects);
|
2021-01-23 12:07:37 +00:00
|
|
|
fill_column(used_aggregate_function_combinators, column_aggregate_function_combinator_factory_objects);
|
|
|
|
fill_column(used_database_engines, column_database_factory_objects);
|
|
|
|
fill_column(used_data_type_families, column_data_type_factory_objects);
|
2021-01-21 21:15:11 +00:00
|
|
|
fill_column(used_dictionaries, column_dictionary_factory_objects);
|
|
|
|
fill_column(used_formats, column_format_factory_objects);
|
|
|
|
fill_column(used_functions, column_function_factory_objects);
|
|
|
|
fill_column(used_storages, column_storage_factory_objects);
|
|
|
|
fill_column(used_table_functions, column_table_function_factory_objects);
|
2022-10-21 16:13:36 +00:00
|
|
|
fill_column(used_row_policies, column_row_policies_names);
|
2021-01-21 21:15:11 +00:00
|
|
|
}
|
2021-03-31 17:55:04 +00:00
|
|
|
|
|
|
|
columns[i++]->insert(Tuple{tid.start_csn, tid.local_tid, tid.host_id});
|
2015-06-26 19:23:25 +00:00
|
|
|
}
|
|
|
|
|
2018-05-31 15:54:08 +00:00
|
|
|
void QueryLogElement::appendClientInfo(const ClientInfo & client_info, MutableColumns & columns, size_t & i)
|
|
|
|
{
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(client_info.query_kind == ClientInfo::QueryKind::INITIAL_QUERY);
|
2018-05-31 15:54:08 +00:00
|
|
|
|
|
|
|
columns[i++]->insert(client_info.current_user);
|
|
|
|
columns[i++]->insert(client_info.current_query_id);
|
|
|
|
columns[i++]->insertData(IPv6ToBinary(client_info.current_address.host()).data(), 16);
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(client_info.current_address.port());
|
2018-05-31 15:54:08 +00:00
|
|
|
|
|
|
|
columns[i++]->insert(client_info.initial_user);
|
|
|
|
columns[i++]->insert(client_info.initial_query_id);
|
|
|
|
columns[i++]->insertData(IPv6ToBinary(client_info.initial_address.host()).data(), 16);
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(client_info.initial_address.port());
|
2021-05-20 13:21:42 +00:00
|
|
|
columns[i++]->insert(client_info.initial_query_start_time);
|
|
|
|
columns[i++]->insert(client_info.initial_query_start_time_microseconds);
|
2018-05-31 15:54:08 +00:00
|
|
|
|
2022-04-18 08:18:31 +00:00
|
|
|
columns[i++]->insert(static_cast<UInt64>(client_info.interface));
|
2022-03-28 08:30:34 +00:00
|
|
|
columns[i++]->insert(static_cast<UInt64>(client_info.is_secure));
|
2018-05-31 15:54:08 +00:00
|
|
|
|
|
|
|
columns[i++]->insert(client_info.os_user);
|
|
|
|
columns[i++]->insert(client_info.client_hostname);
|
|
|
|
columns[i++]->insert(client_info.client_name);
|
2020-09-17 12:15:05 +00:00
|
|
|
columns[i++]->insert(client_info.client_tcp_protocol_version);
|
2018-10-22 08:54:54 +00:00
|
|
|
columns[i++]->insert(client_info.client_version_major);
|
|
|
|
columns[i++]->insert(client_info.client_version_minor);
|
|
|
|
columns[i++]->insert(client_info.client_version_patch);
|
2018-05-31 15:54:08 +00:00
|
|
|
|
2022-04-18 08:18:31 +00:00
|
|
|
columns[i++]->insert(static_cast<UInt64>(client_info.http_method));
|
2018-05-31 15:54:08 +00:00
|
|
|
columns[i++]->insert(client_info.http_user_agent);
|
2021-01-21 22:55:45 +00:00
|
|
|
columns[i++]->insert(client_info.http_referer);
|
2020-12-01 21:07:20 +00:00
|
|
|
columns[i++]->insert(client_info.forwarded_for);
|
2018-05-31 15:54:08 +00:00
|
|
|
|
|
|
|
columns[i++]->insert(client_info.quota_key);
|
2022-03-11 09:57:34 +00:00
|
|
|
columns[i++]->insert(client_info.distributed_depth);
|
2018-05-31 15:54:08 +00:00
|
|
|
}
|
2015-06-26 19:23:25 +00:00
|
|
|
}
|