system.replicas
ローカルサーバに存在するレプリケートされたテーブルに関する情報と状態を含みます。このテーブルは監視に使用できます。このテーブルは、すべての Replicated* テーブルに対して 1 行を含みます。
例:
カラム:
database
(String
) - データベース名table
(String
) - テーブル名engine
(String
) - テーブルエンジン名is_leader
(UInt8
) - レプリカがリーダーであるかどうか。 複数のレプリカが同時にリーダーになることができます。レプリカは、merge_tree
設定のreplicated_can_become_leader
を使用してリーダーになることを防ぐことができます。リーダーはバックグラウンドマージのスケジューリングを担当します。リーダーであるかどうかに関係なく、利用可能で ZK にセッションがある任意のレプリカに書き込みが行えます。can_become_leader
(UInt8
) - レプリカがリーダーになることができるかどうか。is_readonly
(UInt8
) - レプリカが読み取り専用モードであるかどうか。 このモードは、設定に ClickHouse Keeper に関するセクションがない場合、ClickHouse Keeper でのセッションの再初期化中に未知のエラーが発生した場合、および ClickHouse Keeper でのセッションの再初期化中にオンになります。is_session_expired
(UInt8
) - ClickHouse Keeper とのセッションが期限切れになった。基本的にis_readonly
と同じです。future_parts
(UInt32
) - INSERT またはマージがまだ行われていない場合に現れるデータパーツの数。parts_to_check
(UInt32
) - 検証待ちのデータパーツの数。パーツが損傷している疑いがある場合、そのパーツは検証キューに入れられます。zookeeper_path
(String
) - ClickHouse Keeper におけるテーブルデータのパス。replica_name
(String
) - ClickHouse Keeper におけるレプリカ名。同じテーブルの異なるレプリカは異なる名前を持ちます。replica_path
(String
) - ClickHouse Keeper におけるレプリカデータのパス。これは 'zookeeper_path/replicas/replica_path' を連結したものと同じです。columns_version
(Int32
) - テーブル構造のバージョン番号。ALTER が何回行われたかを示します。レプリカが異なるバージョンを持っている場合、一部のレプリカがすべての ALTER をまだ行っていないことを意味します。queue_size
(UInt32
) - 実行待ちの操作のためのキューのサイズ。操作にはデータブロックの挿入、マージ、および特定の他のアクションが含まれます。通常、これはfuture_parts
と一致します。inserts_in_queue
(UInt32
) - 実行待ちのデータブロックの挿入の数。挿入は通常、比較的迅速にレプリケートされます。この数が大きい場合、何か問題が発生していることを意味します。merges_in_queue
(UInt32
) - 実行待ちのマージの数。時々、マージは長引くことがあるため、この値が長い間 0 より大きいかもしれません。part_mutations_in_queue
(UInt32
) - 実行待ちのマージの数。queue_oldest_time
(DateTime
) -queue_size
が 0 より大きい場合、最も古い操作がキューに追加された時間を示します。inserts_oldest_time
(DateTime
) -queue_oldest_time
を参照してください。merges_oldest_time
(DateTime
) -queue_oldest_time
を参照してください。part_mutations_oldest_time
(DateTime
) -queue_oldest_time
を参照してください。
次の 4 つのカラムは、ZK にアクティブなセッションがある場合にのみゼロ以外の値を持ちます。
log_max_index
(UInt64
) - 一般的な活動のログの最大エントリ番号。log_pointer
(UInt64
) - レプリカが実行キューにコピーした一般的な活動のログの最大エントリ番号に 1 を加えたもの。log_pointer
がlog_max_index
よりもかなり小さい場合、何か問題があります。last_queue_update
(DateTime
) - 最後にキューが更新された時間。absolute_delay
(UInt64
) - 現在のレプリカの遅延の大きさ(秒)。total_replicas
(UInt8
) - このテーブルの既知のレプリカの合計数。active_replicas
(UInt8
) - ClickHouse Keeper にセッションがあるこのテーブルのレプリカの数(すなわち、機能しているレプリカの数)。lost_part_count
(UInt64
) - テーブル作成以来、すべてのレプリカで失われたデータパーツの数。この値は ClickHouse Keeper に保存され、増加のみ可能です。last_queue_update_exception
(String
) - キューに壊れたエントリが含まれるとき。特に、異なるバージョン間で ClickHouse が後方互換性を破る場合、新しいバージョンによって書き込まれたログエントリが古いバージョンで解析できない場合に重要です。zookeeper_exception
(String
) - ClickHouse Keeper から情報を取得中にエラーが発生した場合に受け取る最後の例外メッセージ。replica_is_active
(Map(String, UInt8)) — レプリカ名とそのレプリカがアクティブであるかのマップ。
すべてのカラムをリクエストすると、各行に対して ClickHouse Keeper からの複数の読み取りが行われるため、テーブルの動作が少し遅くなります。 最後の 4 つのカラム(log_max_index、log_pointer、total_replicas、active_replicas)をリクエストしない場合、テーブルは迅速に動作します。
たとえば、次のようにすべてが正常に機能していることを確認できます:
このクエリが何も返さない場合は、すべてが正常であることを意味します。