LatchとLockの違い

種類概要保持時間主な競合
LatchOracle内部メモリ構造を保護する軽量ロックマイクロ〜ミリ秒バッファキャッシュ、ライブラリキャッシュ
Lock(Enqueue)SQL/DML操作によるユーザーレベルのロック秒〜分以上行ロック、表ロック、シーケンス

全体フローは PART 01。Wait / Undo / Latchセクションの定義は PART 08 — Wait / Undo / Latch 詳細(定義書) を参照。

Latch Activityの読み方

Latch Activity でLatch競合の発生状況を確認します。STATSPACKとAWRで列構成はほぼ同じです。

列名意味注目ポイント
Get RequestsLatch取得要求数
Pct Get Miss取得失敗率0.1%超が問題の目安
Avg Slps/Missミスあたりの平均スリープ回数高いほど深刻な競合
NoWait Requestsノーウェイトモードの要求数
Latch名原因対処
cache buffers chains特定ブロックへのアクセス集中(ホットブロック)対象テーブルのパーティション化、フリーリスト増加
library cacheハードパース多発バインド変数使用、cursor_sharing設定
shared pool共有プール断片化・サイズ不足shared_pool_size増加
row cache objectsデータディクショナリキャッシュ不足shared_pool_size増加

Latch Sleep Breakdown — STATSPACKの特徴

Latch Sleep Breakdown はSTATSPACKに固有のセクションです(AWRには存在しません)。 Latchのスリープ(待機)をスリープ回数ごとに分布表示することで、競合の深刻度をより詳細に把握できます。

Sleeps 列の見方意味診断
Sleeps 1(1回スリープで取得成功)軽度の競合許容範囲の可能性あり
Sleeps 2〜3(複数回のスリープ)中程度の競合対象Latchの原因調査を開始
Sleeps 4以上重度の競合(深刻)緊急対処が必要

💡 Latch Sleep Breakdown の活用方法

Latch Activity の「Pct Get Miss」が低くても、Latch Sleep Breakdown で Sleeps 4以上が多い場合は特定タイミングで激しい競合が発生している可能性があります。Latch Activity との組み合わせで判断してください。

Enqueue Activityの読み方

Enqueue種類意味原因と対処
TX (Transaction)行レベルのトランザクションロックコミット遅延・長時間トランザクション → コミット頻度見直し
TM (DML)テーブルレベルのDMLロック外部キー制約のインデックスなし → FK列にインデックス追加
ST (Space Transaction)空間管理のロックセグメントの自動拡張が頻発 → 初期サイズ調整
HW (High Water Mark)セグメントHWM更新のロック大量INSERT → APPEND hintsや配列INSERT

Buffer Wait Statisticsの読み方

STATSPACKでは Buffer Wait Statistics定義書 PART 07(Advisory / Memory) に含まれています(AWRはPART 08に対応)。 詳細は PART 07 — Advisory / Memory Statistics 詳細(定義書) を参照。

Class意味対処
data block通常データブロックの競合ホットブロック → パーティション化、INITRANS見直し
segment headerセグメントヘッダーの競合フリーリスト(FREELIST GROUPS)の増加
undo header / undo blockUNDOブロックの競合UNDOセグメント数の増加

競合解消の方向性

1
Latch Activity で Pct Get Miss が高いLatchを特定
0.1%超のLatch名で原因を特定する
2
Latch Sleep Breakdown で深刻度を確認
Sleeps 4以上が多い → 緊急対処が必要
3
Enqueue Activity で Lock種類を特定
TX行ロック → 長時間トランザクションの特定と解消
4
Buffer Wait Statistics で熱いクラスを確認
data block → Segment Statisticsで熱いオブジェクトを特定