ClickHouse Cloud でのクエリこのシステムテーブルのデータは、ClickHouse Cloud の各ノードにローカルに保持されています。したがって、すべてのデータを完全に把握するには、
clusterAllReplicas 関数を使用する必要があります。詳細については、こちらを参照してください。説明
flush_interval_milliseconds パラメータで設定します。強制的にフラッシュするには、SYSTEM FLUSH LOGS クエリを使用します。
ClickHouse はテーブルからデータを自動的に削除しません。詳しくは Introduction を参照してください。
system.query_log テーブルには、2 種類のクエリが記録されます。
- クライアントから直接実行された初期クエリ。
- 他のクエリによって開始された子クエリ (分散クエリ実行用) 。これらのクエリでは、親クエリに関する情報が
initial_*カラムに表示されます。
type カラムを参照) に応じて、query_log テーブルに 1 行または 2 行を作成します。
- クエリの実行が成功した場合は、
QueryStart型とQueryFinish型の 2 行が作成されます。 - クエリ処理中にエラーが発生した場合は、
QueryStart型とExceptionWhileProcessing型の 2 つのイベントが作成されます。 - クエリの開始前にエラーが発生した場合は、
ExceptionBeforeStart型の単一イベントが作成されます。
query_log テーブルに記録されるクエリ数を減らせます。
log_formatted_queries 設定を使用すると、整形済みクエリを formatted_query カラムに記録できます。
カラム
hostname(LowCardinality(String)) — クエリを実行しているサーバーのホスト名。type(Enum8(‘QueryStart’ = 1, ‘QueryFinish’ = 2, ‘ExceptionBeforeStart’ = 3, ‘ExceptionWhileProcessing’ = 4)) — クエリ実行時に発生したイベントの種類。値:QueryStart— クエリ実行の正常な開始、QueryFinish— クエリ実行の正常な終了、ExceptionBeforeStart— クエリ実行開始前の例外、ExceptionWhileProcessing— クエリ実行中の例外。event_date(Date) — クエリの開始日付。event_time(DateTime) — クエリの開始時刻。event_time_microseconds(DateTime64(6)) — マイクロ秒精度でのクエリ開始時刻。query_start_time(DateTime) — クエリ実行の開始時刻。query_start_time_microseconds(DateTime64(6)) — マイクロ秒精度で記録されるクエリ実行の開始時刻。query_duration_ms(UInt64) — クエリの実行時間 (ミリ秒) 。read_rows(UInt64) — クエリに関与したすべてのテーブルおよびテーブル関数から読み取られた行の総数です。通常のサブクエリに加え、IN および JOIN のサブクエリも含まれます。分散クエリでは、read_rows にはすべてのレプリカで読み取られた行の総数が含まれます。各レプリカは自身の read_rows の値を送信し、クエリのサーバー側のイニシエーターが、受信したすべての値とローカルの値を集計します。cache の容量はこの値には影響しません。read_bytes(UInt64) — クエリで使用されたすべてのテーブルおよびテーブル関数から読み取られた合計バイト数です。通常のサブクエリに加え、IN および JOIN 用のサブクエリも含まれます。分散クエリでは、read_bytes にはすべてのレプリカで読み取られた行数の合計が含まれます。各レプリカは自身の read_bytes の値を送信し、クエリのイニシエーターであるサーバーが、受信したすべての値とローカルの値を集計します。cache のサイズはこの値に影響しません。written_rows(UInt64) — INSERTクエリでは、書き込まれた行数を示します。その他のクエリでは、カラムの値は0です。written_bytes(UInt64) — INSERTクエリでは、書き込まれたバイト数 (非圧縮) を示します。その他のクエリでは、このカラムの値は 0 です。result_rows(UInt64) — SELECT クエリの結果の行数、または INSERT クエリの行数。result_bytes(UInt64) — クエリ結果の保存に使用されるRAMの量 (バイト単位) 。memory_usage(UInt64) — クエリのメモリ使用量。current_database(LowCardinality(String)) — 現在のデータベース名。query(String) — クエリ文字列。formatted_query(String) — 整形済みのクエリ文字列。normalized_query_hash(UInt64) — リテラル値だけが異なるクエリでは同一となる数値のハッシュ値。query_kind(LowCardinality(String)) — クエリの種別。databases(Array(LowCardinality(String))) — クエリに含まれるデータベース名。tables(Array(LowCardinality(String))) — クエリに含まれるテーブル名。columns(Array(LowCardinality(String))) — クエリ内に含まれるカラム名。partitions(Array(LowCardinality(String))) — クエリに含まれるパーティション名。projections(Array(LowCardinality(String))) — クエリ実行時に使用されたプロジェクションの名前。views(Array(LowCardinality(String))) — クエリに含まれる (マテリアライズドビューまたはライブビュー) の名前。exception_code(Int32) — 例外コード。exception(String) — 例外メッセージ。stack_trace(String) — スタックトレース。クエリが正常に完了した場合は、空文字列です。is_initial_query(UInt8) — クエリタイプ。設定可能な値: 1 — クエリがクライアントによって開始されたことを示します、0 — 分散クエリ実行の一部として、別のクエリによって開始されたことを示します。connection_address(IPv6) — 接続元のクライアント IP アドレス。プロキシ経由で接続している場合は、プロキシのアドレスになります。connection_port(UInt16) — 接続元のクライアントポートです。プロキシ経由で接続している場合は、プロキシのポートになります。user(LowCardinality(String)) — 現在のクエリを実行したユーザー名。query_id(String) — クエリの識別子。address(IPv6) — クエリの実行に使用された IP アドレス。プロキシ経由で接続され、auth_use_forwarded_addressが設定されている場合、これはプロキシではなくクライアントのアドレスになります。port(UInt16) — クエリの実行に使用されたクライアントのポート。プロキシ経由で接続しており、auth_use_forwarded_addressが設定されている場合、これはプロキシではなくクライアント側のポートになります。initial_user(LowCardinality(String)) — 分散クエリ実行時に最初のクエリを実行したユーザー名。initial_query_id(String) — 最初のクエリの ID (分散クエリの実行時) 。initial_address(IPv6) — 親クエリの送信元IPアドレス。initial_port(UInt16) — 親クエリの実行に使用されたクライアントのポート。initial_query_start_time(DateTime) — 元のクエリの開始時刻 (分散クエリ実行時) 。initial_query_start_time_microseconds(DateTime64(6)) — マイクロ秒精度の初期クエリ開始時刻 (分散クエリ実行時) 。authenticated_user(LowCardinality(String)) — セッション内で認証されたユーザー名。interface(UInt8) — クエリの開始元となったインターフェイス。設定可能な値: 1 — TCP、2 — HTTP。is_secure(UInt8) — クエリがセキュアなインターフェイス経由で実行されたかどうかを示すフラグos_user(LowCardinality(String)) —clickhouse-clientを実行しているオペレーティングシステムのユーザー名。client_hostname(LowCardinality(String)) — clickhouse-client または別の TCP クライアントが実行されているクライアントマシンのホスト名。client_name(LowCardinality(String)) — clickhouse-client または他の TCP クライアントの名前。client_revision(UInt32) — clickhouse-client または他の TCP クライアントのリビジョン。client_version_major(UInt32) — clickhouse-client またはその他の TCP クライアントのメジャーバージョン。client_version_minor(UInt32) — clickhouse-client またはその他の TCP クライアントのマイナーバージョン。client_version_patch(UInt32) — clickhouse-client または他の TCP クライアントのバージョンにおけるパッチ部分。script_query_number(UInt32) — clickhouse-client で、複数のクエリを含むスクリプト内のクエリ番号。script_line_number(UInt32) — clickhouse-client において、複数のクエリを含むスクリプトでクエリが開始される行番号です。http_method(UInt8) — クエリの実行を開始した HTTP メソッド。設定可能な値: 0 — クエリは TCP インターフェイス経由で実行された、1 — GET メソッドが使用された、2 — POST メソッドが使用された。http_user_agent(LowCardinality(String)) — HTTPクエリで送信されるHTTPヘッダー UserAgent。http_referer(String) — HTTPクエリで渡されるHTTPヘッダーのReferer (クエリを行うページの絶対アドレスまたは部分的なアドレスを含みます) 。forwarded_for(文字列) — HTTPクエリで渡される X-Forwarded-For HTTPヘッダー。quota_key(String) — quotas 設定で指定するクォータキー (keyed を参照) 。distributed_depth(UInt64) — クエリがサーバー間で何回転送されたか。revision(UInt32) — ClickHouseのリビジョン番号。log_comment(String) — ログコメント。max_query_size を超えない任意の文字列を設定できます。定義されていない場合は空文字列です。thread_ids(Array(UInt64)) — クエリの実行に関与しているスレッド ID。これらのスレッドが同時に実行されていたとは限りません。peak_threads_usage(UInt64) — クエリの実行時に同時に使用されるスレッド数の最大値。ProfileEvents(Map(LowCardinality(String), UInt64)) — さまざまなメトリクスを計測する ProfileEvents です。これらの説明はsystem.eventsテーブルにありますSettings(Map(LowCardinality(String), LowCardinality(String))) — クライアントがクエリを実行したときに変更された設定。設定の変更を記録するには、log_query_settings パラメータを 1 に設定します。used_aggregate_functions(Array(LowCardinality(String))) — クエリの実行中に使用された集約関数の正式名。used_aggregate_function_combinators(Array(LowCardinality(String))) — クエリ実行時に使用された集約関数コンビネータの正準名。used_database_engines(Array(LowCardinality(String))) — クエリの実行中に使用されたデータベースエンジンの正式名称。used_data_type_families(Array(LowCardinality(String))) — クエリ実行時に使用されたデータ型ファミリーの標準名。used_dictionaries(Array(LowCardinality(String))) — クエリ実行時に使用された辞書の正規名。used_formats(Array(LowCardinality(String))) — クエリ実行時に使用されたフォーマットの正式名。used_functions(Array(LowCardinality(String))) — クエリの実行中に使用された関数の正式名。used_storages(Array(LowCardinality(String))) — クエリの実行時に使用されたストレージの正式名称。used_table_functions(Array(LowCardinality(String))) — クエリの実行時に使用されたテーブル関数の正規名。used_executable_user_defined_functions(Array(LowCardinality(String))) — クエリ実行時に使用された実行可能なユーザー定義関数の正規名。used_sql_user_defined_functions(Array(LowCardinality(String))) — クエリ実行中に使用された SQL ユーザー定義関数の正規名。used_row_policies(Array(LowCardinality(String))) — クエリ実行中に使用された行ポリシー名の一覧。used_privileges(Array(LowCardinality(String))) — クエリ実行時に正常にチェックされた権限。missing_privileges(Array(LowCardinality(String))) — クエリ実行時に不足している権限。transaction_id(Tuple(UInt64, UInt64, UUID)) — このクエリが属するトランザクションの識別子。query_cache_usage(Enum8(‘Unknown’ = 0, ‘None’ = 1, ‘Write’ = 2, ‘Read’ = 3)) — クエリ実行時のクエリキャッシュの使用状況。値: ‘Unknown’ = 状態不明、‘None’ = クエリ結果はクエリ結果キャッシュに書き込まれず、クエリ結果キャッシュからも読み出されませんでした、‘Write’ = クエリ結果はクエリ結果キャッシュに書き込まれました、‘Read’ = クエリ結果はクエリ結果キャッシュから読み出されました。asynchronous_read_counters(Map(LowCardinality(String), UInt64)) — 非同期読み込みのメトリクス。is_internal(UInt8) — 内部で実行される補助クエリかどうかを示します。
ProfileEvents.Names—mapKeys(ProfileEvents)の別名です。ProfileEvents.Values—mapValues(ProfileEvents)の別名です。Settings.Names—mapKeys(Settings)の別名です。Settings.Values—mapValues(Settings)の別名です。
例
system.query_log は各ノードごとにローカルです。すべてのエントリを確認するには、clusterAllReplicas 経由でクエリする必要があります。
たとえば、“default” クラスター内のすべてのレプリカの query_log の行を集約するには、次のように記述できます。
関連項目
- system.query_thread_log — このテーブルには、各クエリ実行スレッドの情報が含まれています。