前回のまとめ。
-
innodb_lock_monitor
を使えば、ロックのタイプごとにモードや詳細モード、範囲が確認できる - あるトランザクションにおいて、読み取り時にどのバージョンが参照されるかもわかる
- 出力内容の読み方についてのドキュメントがないので、他のドキュメントから推測したりソースを読んだりした
読み方
(1) // ---TRANSACTION 31826445, ACTIVE 627 sec
// 2 lock struct(s), heap size 320, 1 row lock(s)
// MySQL thread id 4, OS thread handle 0x7ac, query id 18 localhost ::1 root cleaning up
(2) // Trx read view will not see trx with id >= 31826446, sees < 31826443
(3) // TABLE LOCK table `til`.`test` trx id 31826445 lock mode IS
(4) // RECORD LOCKS space id 42733 page no 3 n bits 72 index `PRIMARY` of table `til`.`test` trx id 31826445 lock mode S
(5) // Record lock, heap no 2 PHYSICAL RECORD: n_fields 4; compact format; info bits 0
(6) // 0: len 4; hex 80000001; asc ;;
(6) // 1: len 6; hex 000001e5a00b; asc ;;
(6) // 2: len 7; hex 8b000001750110; asc u ;;
(6) // 3: len 4; hex 8000000a; asc ;;
- (1)トランザクションごとに
---TRANSACTION ...
で区切られる。TRANSACTION
の後にある数字がトランザクションID。 - (2)このトランザクションがどのバージョンを読み取るか。トランザクションIDで表示されている。どの範囲になるかはトランザクション分離レベルによって異なるはず。
- (3)テーブルロックの情報。ロックのモードが表示される。
- (4)行ロックの情報。ロックの精密なモード(レコードロック、ギャップロック、ネクストキーロック)が表示される。
- (5)ロックされたレコードの情報。レコード1行ごとに出力される。
n_fields
の数ぶんの(6)を持つ。 - (6)フィールドの情報。フィールド1つごとに出力される。
- 実際のフィールドに加えてトランザクションIDとロールポインタの行が追加される
- 表示される内容は
通し番号: len 長さ; hex 16進データ; asc ascii表示; 表示時の省略情報; externalデータ;
- (6)に表示されるフィールドの順番
- 主キーのフィールド
- プライマリキーか、なければNOT NULLのUNIQUEインデックス
- 該当するインデックスが複合キーの場合、インデックスの順番で表示
- プライマリキーもNOT NULLのUNIQUEキーもない場合、6バイトの行IDが自動で追加される
- トランザクションID(6バイト):最後にこの行を更新したトランザクションのIDが格納されている
- ロールポインタ(7バイト):Undoログの場所を指しているらしい
- それ以外のフィールド(定義順)
- 主キーのフィールド
- (たぶんクラスタインデックスの物理構成そのまま)
出力と出力している関数の対応
+------------ // ------------
| // TRANSACTIONS
(1)| // ------------
| // Trx id counter 31826446
| // Purge done for trx's n:o < 31825964 undo n:o < 0 state: running but idle
+------------ // History list length 431
+------------ // LIST OF TRANSACTIONS FOR EACH SESSION:
| +---- // ---TRANSACTION 31826445, ACTIVE 627 sec
| (3)| // 2 lock struct(s), heap size 320, 1 row lock(s)
| +-(4) // MySQL thread id 4, OS thread handle 0x7ac, query id 18 localhost ::1 root cleaning up
| // Trx read view will not see trx with id >= 31826446, sees < 31826443
| (5) // TABLE LOCK table `til`.`test` trx id 31826445 lock mode IS
| +-------- // RECORD LOCKS space id 42733 page no 3 n bits 72 index `PRIMARY` of table `til`.`test` trx id 31826445 lock mode S
| | (7) // Record lock, heap no 2 PHYSICAL RECORD: n_fields 4; compact format; info bits 0
|(6)| +-(9) // 0: len 4; hex 80000001; asc ;;
| |(8)| (9) // 1: len 6; hex 000001e5a00b; asc ;;
| | | (9) // 2: len 7; hex 8b000001750110; asc u ;;
(2)| +---+-(9) // 3: len 4; hex 8000000a; asc ;;
| //
| +---- // ---TRANSACTION 31826444, ACTIVE 2361 sec
| (3)| // 2 lock struct(s), heap size 320, 1 row lock(s), undo log entries 1
| +-(4) // MySQL thread id 3, OS thread handle 0x1044, query id 10 localhost ::1 root cleaning up
| (5) // TABLE LOCK table `til`.`test` trx id 31826444 lock mode IX
| +-------- // RECORD LOCKS space id 42733 page no 3 n bits 72 index `PRIMARY` of table `til`.`test` trx id 31826444 lock_mode X locks rec but not gap
| | (7) // Record lock, heap no 3 PHYSICAL RECORD: n_fields 4; compact format; info bits 0
|(6)| +-(9) // 0: len 4; hex 80000002; asc ;;
| |(8)| (9) // 1: len 6; hex 000001e5a20c; asc ;;
| | | (9) // 2: len 7; hex 0c00000fd0062f; asc /;;
| +---+-(9) // 3: len 4; hex 800000dc; asc ;;
| //
| (3)+---- // ---TRANSACTION 31826443, ACTIVE 2758 sec
| +-(4) // MySQL thread id 1, OS thread handle 0x954, query id 12 localhost ::1 root cleaning up
+------------ // Trx read view will not see trx with id >= 31826444, sees < 31826444
- lock_print_info_summary
- lock_print_info_all_transactions
- trx_print_low
- thd_security_context
- lock_table_print
- lock_rec_print
- rec_print_new
- rec_print_comp
- ut_print_buf
今回の感想
ソースを読もう!
次回の予定
トランザクション分離レベルごとにinnodb_lock_monitor
を読む。
追記(2017/05/11)
InnoDBのロックに関する用語の確認に合わせて用語を修正。