TiDBダッシュボード監視ページ
モニタリングページでは、TiDB v6.1.0で導入されたパフォーマンス分析およびチューニングツールである「パフォーマンス概要」ダッシュボードを表示できます。「パフォーマンス概要」ダッシュボードを使用すると、パフォーマンスを効率的に分析し、ユーザー応答時間のボトルネックがデータベースにあるかどうかを確認できます。ボトルネックがデータベースにある場合は、データベース時間の概要、ワークロードプロファイル、SQLレイテンシーの内訳を表示することで、データベース内のボトルネックを特定できます。詳細はパフォーマンス分析とチューニングご覧ください。
ページにアクセスする
TiDBダッシュボードにログインし、左側のナビゲーションバーから「モニタリング」をクリックします。パフォーマンス概要ダッシュボードが表示されます。

TiDBクラスターをTiUPを使用してデプロイした場合、Grafanaでパフォーマンス概要ダッシュボードを表示することもできます。このデプロイメントモードでは、監視システム(PrometheusとGrafana)も同時にデプロイされます。詳細については、 TiDB 監視フレームワークの概要参照してください。

パフォーマンス概要の主要指標
パフォーマンス概要ダッシュボードは、TiDB、PD、および TiKV のメトリックを調整し、それぞれを次のセクションで表示します。
概要:データベース時間とSQL実行時間の概要。概要で異なる色を確認することで、データベースのワークロードプロファイルとパフォーマンスのボトルネックを素早く特定できます。
負荷プロファイル: データベース QPS、接続情報、アプリケーションが TiDB と対話する MySQL コマンド タイプ、データベース内部 TSO および KV 要求 OPS、TiKV および TiDB のリソース使用量など、主要なメトリックとリソース使用量。
トップダウンのレイテンシーの内訳: クエリレイテンシーと接続アイドル時間の比率、クエリレイテンシーの内訳、実行中の TSO/KV 要求レイテンシー、TiKV 内の書き込みレイテンシーの内訳。
次のセクションでは、パフォーマンス概要ダッシュボードのメトリックについて説明します。
SQLタイプ別のデータベース時間
database time: 1秒あたりの合計データベース時間sql_type: 各タイプのSQL文が1秒あたりに消費するデータベース時間
SQLフェーズ別のデータベース時間
database time: 1秒あたりの合計データベース時間get token/parse/compile/execute: 4つのSQL処理フェーズで消費されたデータベース時間
SQL実行フェーズは緑色で、その他のフェーズは全体的に赤色で表示されます。緑色以外の領域が大きい場合は、実行フェーズ以外のフェーズでデータベース時間が大量に消費されていることを意味し、さらなる原因分析が必要です。
SQL実行時間の概要
execute time: SQL実行中に1秒あたりに消費されたデータベース時間tso_wait: SQL実行中の1秒あたりの同時TSO待機時間kv request type:SQL実行中に各KVリクエストタイプを1秒あたりに待機する時間。KVリクエストは同時実行されるため、合計KVリクエスト待機時間はSQL実行時間を超える場合があります。
緑色のメトリクスは一般的なKV書き込みリクエスト(プリライトやコミットなど)を表し、青色のメトリクスは一般的な読み取りリクエストを表します。その他の色のメトリクスは、注意が必要な予期しない状況を表します。例えば、悲観的ロックKVリクエストは赤色で、TSO待機は濃い茶色で表示されます。
青または緑以外の領域が大きい場合は、SQL実行中にボトルネックが発生していることを意味します。例:
- 重大なロック競合が発生した場合、赤色の領域が大きな割合を占めることになります。
- TSO の待ち時間に過度に時間がかかってしまうと、濃い茶色の領域が大きな割合を占めることになります。
QPS
すべてUPDATE TiDB インスタンスで 1 秒あたりに実行された SQL 文の数 (タイプ別: SELECTなどINSERT
CPSタイプ別
タイプに基づいて、すべての TiDB インスタンスによって 1 秒あたりに処理されるコマンドの数
プランキャッシュOPSを使用したクエリ
すべての TiDB インスタンスにおける 1 秒あたりのプラン キャッシュを使用するクエリの数
KV/TSO リクエスト OPS
- kvリクエスト合計: すべてのTiDBインスタンスにおける1秒あたりのKVリクエストの合計数
- タイプ別の KV リクエスト数:
GetなどCommitタイプに基づいてPrewriteすべての TiDB インスタンスでの 1 秒あたりの KV リクエスト数 - tso - cmd: TiDB がすべての TiDB インスタンスの PD に送信する 1 秒あたりの gRPC リクエストの数。各 gRPC リクエストには、TSO リクエストのバッチが含まれます。
- tso - リクエスト: すべての TiDB インスタンスにおける 1 秒あたりの TSO リクエスト数
通常、 tso - request tso - cmdで割った値が、1 秒あたりの TSO 要求バッチの平均サイズになります。
接続数
total: すべてのTiDBインスタンスへの接続数active connections: すべてのTiDBインスタンスへのアクティブな接続の数- 各TiDBインスタンスへの接続数
TiDB CPU/メモリ
CPU-Avg: すべての TiDB インスタンスの平均 CPU 使用率CPU-Delta: すべての TiDB インスタンスの最大 CPU 使用率からすべての TiDB インスタンスの最小 CPU 使用率を引いた値CPU-Max: すべての TiDB インスタンスの最大 CPU 使用率CPU-Quota: TiDBが使用できるCPUコアの数Mem-Max: すべての TiDB インスタンスの最大メモリ使用率
TiKV CPU/メモリ
CPU-Avg: すべての TiKV インスタンスの平均 CPU 使用率CPU-Delta: すべての TiKV インスタンスの最大 CPU 使用率からすべての TiKV インスタンスの最小 CPU 使用率を引いた値CPU-Max: すべての TiKV インスタンスの最大 CPU 使用率CPU-Quota: TiKVが使用できるCPUコアの数Mem-Max: すべての TiKV インスタンスの最大メモリ使用率
PD CPU/メモリ
CPU-Max: すべてのPDインスタンスの最大CPU使用率CPU-Quota: PDが使用できるCPUコアの数Mem-Max: すべてのPDインスタンスの最大メモリ使用率
トラフィックを読む
TiDB -> Client: TiDBからクライアントへの送信トラフィック統計Rocksdb -> TiKV:storageレイヤー内での読み取り操作中に TiKV が RocksDB から取得するデータフロー
書き込みトラフィック
Client -> TiDB: クライアントから TiDB への受信トラフィック統計TiDB -> TiKV: general: フォアグラウンドトランザクションが TiDB から TiKV に書き込まれる速度TiDB -> TiKV: internal: 内部トランザクションが TiDB から TiKV に書き込まれる速度TiKV -> Rocksdb: TiKVからRocksDBへの書き込み操作の流れRocksDB Compaction: RocksDBの圧縮操作によって生成された合計読み取りおよび書き込みI/Oフロー
間隔
Duration: 実行時間- クライアントからのリクエストをTiDBが受信してから、TiDBがそのリクエストを実行し、結果をクライアントに返すまでの時間。通常、クライアントからのリクエストはSQL文の形式で送信されますが、この時間には
COM_PING、COM_SLEEP、COM_STMT_FETCH、COM_SEND_LONG_DATAなどのコマンドの実行時間も含まれる場合があります。 - TiDBはマルチクエリをサポートしています。つまり、クライアントは一度に複数のSQL文(例:
select 1; select 1; select 1;を送信できます。この場合、このクエリの合計実行時間には、すべてのSQL文の実行時間が含まれます。
- クライアントからのリクエストをTiDBが受信してから、TiDBがそのリクエストを実行し、結果をクライアントに返すまでの時間。通常、クライアントからのリクエストはSQL文の形式で送信されますが、この時間には
avg: すべてのリクエストを実行する平均時間99: すべてのリクエストを実行するためのP99期間avg by type: すべての TiDB インスタンス内のすべてのリクエストを実行するのにかかった平均時間 (タイプ別UPDATE収集INSERT:SELECT
接続アイドル時間
接続アイドル期間は、接続がアイドル状態にある期間を示します。
avg-in-txn: 接続がトランザクション内にあるときの平均接続アイドル期間avg-not-in-txn: 接続がトランザクション内にない場合の平均接続アイドル期間99-in-txn: 接続がトランザクション内にある場合の P99 接続アイドル期間99-not-in-txn: 接続がトランザクション内にない場合の P99 接続アイドル期間
解析期間、コンパイル期間、実行期間
Parse Duration: SQL文の解析に要した時間Compile Duration: 解析されたSQL ASTを実行プランにコンパイルするのにかかる時間Execution Duration: SQL文の実行計画の実行に費やされた時間
これら 3 つのメトリックにはすべて、すべての TiDB インスタンスの平均期間と 99 パーセンタイル期間が含まれます。
平均 TiDB KV リクエスト期間
Get 、 Prewrite 、 Commitを含むタイプに基づいて、すべての TiDB インスタンスでの KV 要求の実行に費やされた平均時間。
平均 TiKV GRPC 期間
kv_get 、 kv_prewrite 、 kv_commitを含むタイプに基づいて、すべての TiKV インスタンスでの gRPC リクエストの実行に費やされた平均時間。
PD TSO 待機/RPC 期間
wait - avg: すべての TiDB インスタンスで PD が TSO を返すのを待つ平均時間rpc - avg: PDにTSOリクエストを送信してからすべてのTiDBインスタンスでTSOを受信するまでの平均時間wait - 99: すべての TiDB インスタンスで PD が TSO を返すのを待つ P99 時間rpc - 99: PDにTSOリクエストを送信してからすべてのTiDBインスタンスでTSOを受信するまでのP99時間
ストレージ非同期書き込み期間、保存期間、適用期間
Storage Async Write Duration: 非同期書き込みにかかった時間Store Duration: 非同期書き込み中のストアループで消費された時間Apply Duration: 非同期書き込み中の適用ループで消費された時間
これら 3 つのメトリックにはすべて、すべての TiKV インスタンスの平均期間と P99 期間が含まれます。
平均storage非同期書き込み時間 = 平均保存時間 + 平均適用時間
追加ログ期間、コミットログ期間、適用ログ期間
Append Log Duration: Raftがログを追加するのにかかった時間Commit Log Duration: Raftがログをコミットするのにかかる時間Apply Log Duration: Raftがログを適用するのに要した時間
これら 3 つのメトリックにはすべて、すべての TiKV インスタンスの平均期間と P99 期間が含まれます。