SHOW PROC
デスクリプション
Procシステムは、Dorisのユニークな機能です。Linuxを使用したことがある学生は、この概念をよく理解できるでしょう。Linuxシステムでは、procは仮想ファイルシステムであり、通常/procディレクトリにマウントされます。ユーザーは、このファイルシステムを通じてシステムの内部データ構造を表示できます。例えば、/proc/pidを通じて指定したpidプロセスの詳細を表示できます。
Linuxのprocシステムと同様に、Dorisのprocシステムもディレクトリのような構造に編成されており、ユーザーが指定した「ディレクトリパス(proc path)」に応じて異なるシステム情報を表示します。
procシステムは主にシステム管理者向けに設計されており、システム内部のいくつかの実行状態を便利に表示できるようになっています。例えば、Tableのtabletステータス、クラスターのバランス状態、さまざまなジョブのステータスなどです。これは非常に有用な機能です。
DorisでProcシステムを表示する方法は2つあります。
- Dorisが提供するWEB UIインターフェースを通じて表示する。アドレスにアクセス:
http://FE_IP:FE_HTTP_PORT - もう一つの方法はコマンドによるものです
DorisのPROCがサポートするすべてのコマンドは、 SHOW PROC "/";を通じて確認できます。
MySQLクライアントを通じてDorisに接続した後、SHOW PROC文を実行して指定したprocディレクトリの情報を表示できます。procディレクトリは「/」で始まる絶対パスです。
show proc文の結果は二次元Tableで表示されます。そして通常、結果Tableの最初の列はprocの次のサブディレクトリです。
mysql> show proc "/";
+---------------------------+
| name |
+---------------------------+
| auth |
| backends |
| bdbje |
| brokers |
| catalogs |
| cluster_balance |
| cluster_health |
| colocation_group |
| current_backend_instances |
| current_queries |
| current_query_stmts |
| dbs |
| diagnose |
| frontends |
| jobs |
| load_error_hub |
| monitor |
| resources |
| routine_loads |
| statistic |
| stream_loads |
| tasks |
| transactions |
| trash |
+---------------------------+
23 rows in set (0.00 sec)
illustrate:
- auth: ユーザー名と対応する権限情報
- backends: クラスター内のBEのノードリストを表示します。SHOW BACKENDSと同等です
- bdbje: bdbjeデータベースリストを表示するには、
fe.confファイルを変更してenable_bdbje_debug_mode=trueを追加し、sh start_fe.sh --daemonを使用してFEを開始してdebugモードに入る必要があります。debugモードに入ると、http serverとMySQLServerのみが開始され、BDBJEインスタンスが開かれますが、メタデータの読み込みやその後の起動プロセスは実行されません。 - brokers : クラスターbrokerノード情報を表示します。SHOW BROKERと同等です
- catalogs : 現在作成されているデータカタログを表示します。SHOW CATALOGSと同等です
- cluster_balance : クラスターのバランスを確認するには、Data Copy Managementを参照してください
- cluster_health:
SHOW PROC '/cluster_health/tablet_health';文を実行して、クラスター全体のレプリカステータスを表示します。 - colocation_group : このコマンドは、クラスター内の既存のGroup情報を表示できます。詳細については、Colocation Joinの章を参照してください
- current_backend_instances : 現在ジョブを実行しているbeノードのリストを表示します
- current_queries : 実行中のクエリのリスト、現在実行中のSQL文を表示します。
- current_query_stmts: 現在実行中のクエリを返します。
- dbs: 主にDorisクラスター内の各データベースとTableのメタデータ情報を表示するために使用されます。この情報には、Table構造、パーティション、マテリアライズドビュー、データシャードとレプリカなどが含まれます。このディレクトリとそのサブディレクトリを通じて、クラスター内のTableメタデータを明確に表示し、データスキュー、レプリカ障害などの問題を特定できます。
- diagnose: クラスター内の一般的な管理制御問題を報告および診断します。レプリカバランスと移行、トランザクション例外などが含まれます。
- frontends: クラスター内のすべてのFEノード情報を表示します。IPアドレス、ロール、ステータス、マスターかどうかなどが含まれます。SHOW FRONTENDSと同等です
- jobs: すべての種類のジョブの統計を表示します。特定の
dbIdが指定された場合、そのデータベースの統計データを返します。dbIdが-1の場合、すべてのデータベースの総統計データを返します - load_error_hub: Dorisは、ロードジョブで生成されたエラー情報をエラーハブに一元的に保存することをサポートしています。その後、
SHOW LOAD WARNINGS;文を使用してエラーメッセージを直接表示できます。ここに表示されるのは、エラーハブの設定情報です。 - monitor : FE JVMのリソース使用状況を表示します
- resources : システムリソースを表示します。通常のアカウントは、USAGE_PRIV権限を持つリソースのみ表示できます。rootアカウントとadminアカウントのみがすべてのリソースを表示できます。SHOW RESOURCESと同等です
- routine_loads: すべてのルーチンロードジョブ情報を表示します。ジョブ名、ステータスなどが含まれます。
- statistics: 主にDorisクラスター内のデータベース、Table、パーティション、シャード、レプリカの数をまとめて表示するために使用されます。また、正常でないコピーの数も表示されます。この情報は、全体的なクラスターメタ情報のサイズを制御するのに役立ちます。全体的な視点からクラスターのシャーディング状況を把握し、クラスターシャーディングの健全性を迅速にチェックできます。これにより、問題のあるデータシャードをさらに特定できます。
- stream_loads: 実行中のストリームロードタスクを返します。
- tasks : さまざまなジョブのタスクの総数と失敗数を表示します。
- transactions : 指定されたトランザクションIDのトランザクション詳細を表示するために使用されます。SHOW TRANSACTIONと同等です
- trash: この文は、バックエンドでガベージデータが占有する容量を表示するために使用されます。SHOW TRASHと同等です
例
-
例えば、"/dbs"はすべてのデータベースを表示し、"/dbs/10002"はID 10002のデータベース下のすべてのTableを表示します
mysql> show proc "/dbs/10002";
+---------+----------------------+----------+---------------------+--------------+--------+------+--------------------------+--------------+
| TableId | TableName | IndexNum | PartitionColumnName | PartitionNum | State | Type | LastConsistencyCheckTime | ReplicaCount |
+---------+----------------------+----------+---------------------+--------------+--------+------+--------------------------+--------------+
| 10065 | dwd_product_live | 1 | dt | 9 | NORMAL | OLAP | NULL | 18 |
| 10109 | ODS_MR_BILL_COSTS_DO | 1 | NULL | 1 | NORMAL | OLAP | NULL | 1 |
| 10119 | test | 1 | NULL | 1 | NORMAL | OLAP | NULL | 1 |
| 10124 | test_parquet_import | 1 | NULL | 1 | NORMAL | OLAP | NULL | 1 |
+---------+----------------------+----------+---------------------+--------------+--------+------+--------------------------+--------------+
4 rows in set (0.00 sec) -
クラスター内のすべてのデータベースTable数に関する情報を表示します。
mysql> show proc '/statistic';
+-------+----------------------+----------+--------------+----------+-----------+------------+
| DbId | DbName | TableNum | PartitionNum | IndexNum | TabletNum | ReplicaNum |
+-------+----------------------+----------+--------------+----------+-----------+------------+
| 10002 | default_cluster:test | 4 | 12 | 12 | 21 | 21 |
| Total | 1 | 4 | 12 | 12 | 21 | 21 |
+-------+----------------------+----------+--------------+----------+-----------+------------+
2 rows in set (0.00 sec) -
次のコマンドを使用して、クラスター内の既存のGroup情報を表示できます。
SHOW PROC '/colocation_group';
+-------------+--------------+--------------+------------+----------------+----------+----------+
| GroupId | GroupName | TableIds | BucketsNum | ReplicationNum | DistCols | IsStable |
+-------------+--------------+--------------+------------+----------------+----------+----------+
| 10005.10008 | 10005_group1 | 10007, 10040 | 10 | 3 | int(11) | true |
+-------------+--------------+--------------+------------+----------------+----------+----------+
- GroupId: グループのクラスター全体でユニークな識別子です。前半はdb id、後半はgroup idです。
- GroupName: Groupのフルネームです。
- TabletIds: このGroupに含まれるTableのidリストです。
- BucketsNum: バケット数です。
- ReplicationNum: レプリカ数です。
- DistCols: 分散カラム、つまりバケットカラムの型です。
- IsStable: Groupが安定しているかどうかです(安定性の定義については、
Colocation replica balance and repairセクションを参照してください)。
-
以下のコマンドを使用して、Groupのデータ分散をさらに詳しく確認できます:
SHOW PROC '/colocation_group/10005.10008';
+-------------+---------------------+
| BucketIndex | BackendIds |
+-------------+---------------------+
| 0 | 10004, 10002, 10001 |
| 1 | 10003, 10002, 10004 |
| 2 | 10002, 10004, 10001 |
| 3 | 10003, 10002, 10004 |
| 4 | 10002, 10004, 10003 |
| 5 | 10003, 10002, 10001 |
| 6 | 10003, 10004, 10001 |
| 7 | 10003, 10004, 10002 |
+-------------+---------------------+
- BucketIndex: バケットシーケンスのインデックス。
- BackendIds: バケット内のデータシャードが配置されているBEノードIDのリスト。
-
様々なジョブのタスクの総数と失敗数を表示する。
mysql> show proc '/tasks';
+-------------------------+-----------+----------+
| TaskType | FailedNum | TotalNum |
+-------------------------+-----------+----------+
| CREATE | 0 | 0 |
| DROP | 0 | 0 |
| PUSH | 0 | 0 |
| CLONE | 0 | 0 |
| STORAGE_MEDIUM_MIGRATE | 0 | 0 |
| ROLLUP | 0 | 0 |
| SCHEMA_CHANGE | 0 | 0 |
| CANCEL_DELETE | 0 | 0 |
| MAKE_SNAPSHOT | 0 | 0 |
| RELEASE_SNAPSHOT | 0 | 0 |
| CHECK_CONSISTENCY | 0 | 0 |
| UPLOAD | 0 | 0 |
| DOWNLOAD | 0 | 0 |
| CLEAR_REMOTE_FILE | 0 | 0 |
| MOVE | 0 | 0 |
| REALTIME_PUSH | 0 | 0 |
| PUBLISH_VERSION | 0 | 0 |
| CLEAR_ALTER_TASK | 0 | 0 |
| CLEAR_TRANSACTION_TASK | 0 | 0 |
| RECOVER_TABLET | 0 | 0 |
| STREAM_LOAD | 0 | 0 |
| UPDATE_TABLET_META_INFO | 0 | 0 |
| ALTER | 0 | 0 |
| INSTALL_PLUGIN | 0 | 0 |
| UNINSTALL_PLUGIN | 0 | 0 |
| Total | 0 | 0 |
+-------------------------+-----------+----------+
26 rows in set (0.01 sec) -
クラスター全体のレプリカステータスを表示します。
mysql> show proc '/cluster_health/tablet_health';
+----------+---------------------------+-----------+------------+-------------------+----------------------+----------------------+--------------+----------------------------+-------------------------+-------------------+---------------------+----------------------+----------------------+------------------+-----------------------------+-----------------+-------------+------------+
| DbId | DbName | TabletNum | HealthyNum | ReplicaMissingNum | VersionIncompleteNum | ReplicaRelocatingNum | RedundantNum | ReplicaMissingInClusterNum | ReplicaMissingForTagNum | ForceRedundantNum | ColocateMismatchNum | ColocateRedundantNum | NeedFurtherRepairNum | UnrecoverableNum | ReplicaCompactionTooSlowNum | InconsistentNum | OversizeNum | CloningNum |
+----------+---------------------------+-----------+------------+-------------------+----------------------+----------------------+--------------+----------------------------+-------------------------+-------------------+---------------------+----------------------+----------------------+------------------+-----------------------------+-----------------+-------------+------------+
| 25852112 | default_cluster:bowen | 1920 | 1920 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 25342914 | default_cluster:bw | 128 | 128 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2575532 | default_cluster:cps | 1440 | 1440 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 16 | 0 |
| 26150325 | default_cluster:db | 38374 | 38374 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 453 | 0 |
+----------+---------------------------+-----------+------------+-------------------+----------------------+----------------------+--------------+----------------------------+-------------------------+-------------------+---------------------+----------------------+----------------------+------------------+-----------------------------+-----------------+-------------+------------+
4 rows in set (0.01 sec)
DbId が 25852112 などのデータベース配下でレプリカのステータスを確認します。
mysql> show proc '/cluster_health/tablet_health/25852112';
-
クラスタ管理の問題を報告し診断する
MySQL > show proc "/diagnose";
+-----------------+----------+------------+
| Item | ErrorNum | WarningNum |
+-----------------+----------+------------+
| cluster_balance | 2 | 0 |
| Total | 2 | 0 |
+-----------------+----------+------------+
2 rows in set
View replicaのバランス移行の問題
```sql
MySQL > show proc "/diagnose/cluster_balance";
+-----------------------+--------+-------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------+------------+
| Item | Status | Content | Detail Cmd | Suggestion |
+-----------------------+--------+-------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------+------------+
| Tablet Health | ERROR | healthy tablet num 691 < total tablet num 1014 | show proc "/cluster_health/tablet_health"; | <null> |
| BeLoad Balance | ERROR | backend load not balance for tag {"location" : "default"}, low load backends [], high load backends [10009] | show proc "/cluster_balance/cluster_load_stat/location_default/HDD" | <null> |
| Disk Balance | OK | <null> | <null> | <null> |
| Colocate Group Stable | OK | <null> | <null> | <null> |
| History Tablet Sched | OK | <null> | <null> | <null> |
+-----------------------+--------+-------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------+------------+
5 rows in set
```
キーワード
SHOW, PROC