MySQL鎖情況查看命令
本文介紹如何在MySQL數(shù)據(jù)庫中分析鎖的情況及處理思路。
MySQL版本
mysql> select version(); +------------+ | version() | +------------+ | 5.7.38-log | +------------+ 1 row in set (0.01 sec)
模擬鎖產(chǎn)生
A會話加鎖
mysql> show create table t\G; *************************** 1. row *************************** ? ? ? ?Table: t Create Table: CREATE TABLE `t` ( ? `id` int(11) NOT NULL, ? `name` varchar(10) COLLATE utf8mb4_unicode_ci DEFAULT NULL, ? PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci 1 row in set (0.00 sec) ERROR:? No query specified mysql> select * from t; +----+------+ | id | name | +----+------+ | ?1 | a ? ?| | ?2 | s ? ?| | ?3 | c ? ?| | ?4 | d ? ?| | ?5 | e ? ?| +----+------+ 5 rows in set (0.00 sec) mysql> begin; Query OK, 0 rows affected (0.00 sec) mysql> select * from t where id<5 for update; +----+------+ | id | name | +----+------+ | ?1 | a ? ?| | ?2 | s ? ?| | ?3 | c ? ?| | ?4 | d ? ?| +----+------+ 4 rows in set (0.00 sec)
B會話插入數(shù)據(jù),造成鎖等待現(xiàn)象
mysql> insert into t values(0,'null');
這里介紹MySQL查看鎖的3個數(shù)據(jù)字典表,分別是位于information_schema數(shù)據(jù)庫下的innodb_trx、innodb_lock_waits、innodb_locks三張表,查看步驟如下:
先看innodb_trx表
mysql> use information_schema; Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed mysql> select * from innodb_trx\G; *************************** 1. row *************************** ? ? ? ? ? ? ? ? ? ? trx_id: 8553 ? ? ? ? ? ? ? ? ?trx_state: LOCK WAIT ? ? ? ? ? ? ? ?trx_started: 2022-12-14 16:52:29 ? ? ?trx_requested_lock_id: 8553:45:3:2 ? ? ? ? ? trx_wait_started: 2022-12-14 16:52:29 ? ? ? ? ? ? ? ? trx_weight: 2 ? ? ? ?trx_mysql_thread_id: 22 ? ? ? ? ? ? ? ? ?trx_query: insert into t values(0,'null') ? ? ? ?trx_operation_state: inserting ? ? ? ? ?trx_tables_in_use: 1 ? ? ? ? ?trx_tables_locked: 1 ? ? ? ? ? trx_lock_structs: 2 ? ? ?trx_lock_memory_bytes: 1136 ? ? ? ? ? ?trx_rows_locked: 1 ? ? ? ? ?trx_rows_modified: 0 ? ?trx_concurrency_tickets: 0 ? ? ? ?trx_isolation_level: REPEATABLE READ ? ? ? ? ?trx_unique_checks: 1 ? ? trx_foreign_key_checks: 1 trx_last_foreign_key_error: NULL ?trx_adaptive_hash_latched: 0 ?trx_adaptive_hash_timeout: 0 ? ? ? ? ? trx_is_read_only: 0 trx_autocommit_non_locking: 0 *************************** 2. row *************************** ? ? ? ? ? ? ? ? ? ? trx_id: 8552 ? ? ? ? ? ? ? ? ?trx_state: RUNNING ? ? ? ? ? ? ? ?trx_started: 2022-12-14 16:51:39 ? ? ?trx_requested_lock_id: NULL ? ? ? ? ? trx_wait_started: NULL ? ? ? ? ? ? ? ? trx_weight: 2 ? ? ? ?trx_mysql_thread_id: 20 ? ? ? ? ? ? ? ? ?trx_query: NULL ? ? ? ?trx_operation_state: NULL ? ? ? ? ?trx_tables_in_use: 0 ? ? ? ? ?trx_tables_locked: 1 ? ? ? ? ? trx_lock_structs: 2 ? ? ?trx_lock_memory_bytes: 1136 ? ? ? ? ? ?trx_rows_locked: 5 ? ? ? ? ?trx_rows_modified: 0 ? ?trx_concurrency_tickets: 0 ? ? ? ?trx_isolation_level: REPEATABLE READ ? ? ? ? ?trx_unique_checks: 1 ? ? trx_foreign_key_checks: 1 trx_last_foreign_key_error: NULL ?trx_adaptive_hash_latched: 0 ?trx_adaptive_hash_timeout: 0 ? ? ? ? ? trx_is_read_only: 0 trx_autocommit_non_locking: 0 2 rows in set (0.00 sec) ERROR:? No query specified mysql> show full processlist; +----+--------+-----------+--------------------+---------+------+----------+--------------------------------+ | Id | User ? | Host ? ? ?| db ? ? ? ? ? ? ? ? | Command | Time | State ? ?| Info ? ? ? ? ? ? ? ? ? ? ? ? ? | +----+--------+-----------+--------------------+---------+------+----------+--------------------------------+ | 20 | root ? | localhost | ray ? ? ? ? ? ? ? ?| Sleep ? | ?132 | ? ? ? ? ?| NULL ? ? ? ? ? ? ? ? ? ? ? ? ? | | 22 | raybak | localhost | ray ? ? ? ? ? ? ? ?| Query ? | ? 82 | update ? | insert into t values(0,'null') | | 24 | root ? | localhost | information_schema | Query ? | ? ?0 | starting | show full processlist ? ? ? ? ?| +----+--------+-----------+--------------------+---------+------+----------+--------------------------------+ 3 rows in set (0.00 sec)
trx_id:唯一事務(wù)id號,本次測試中是8552和8553
trx_state:當前事務(wù)的狀態(tài),本次測試中8553是LOCK WAIT 鎖等待狀態(tài)
trx_wait_started:事務(wù)開始等待時間,本次測試中為2022-12-14 16:52:29
trx_mysql_thread_id:線程id,與show full processlist中的id對應(yīng),本次測試中為22
trx_query:事務(wù)運行的SQL語句,本次測試為insert into t values(0,‘null’)
trx_operation_state:事務(wù)運行的狀態(tài),本次測試為inserting
再看innodb_lock_waits表
mysql> select * from innodb_lock_waits\G; *************************** 1. row *************************** requesting_trx_id: 8553 requested_lock_id: 8553:45:3:2 blocking_trx_id: 8552 blocking_lock_id: 8552:45:3:2 1 row in set, 1 warning (0.00 sec)
requesting_trx_id:請求鎖的事務(wù)id,本次測試為8553
blocking_trx_id:持有鎖的事務(wù)id,也就是造成鎖等待的事務(wù)id,本次測試為8552
再看innodb_locks表
mysql> select * from innodb_locks\G; *************************** 1. row *************************** ? ? lock_id: 8553:45:3:2 lock_trx_id: 8553 ? lock_mode: X,GAP ? lock_type: RECORD ?lock_table: `ray`.`t` ?lock_index: PRIMARY ?lock_space: 45 ? lock_page: 3 ? ?lock_rec: 2 ? lock_data: 1 *************************** 2. row *************************** ? ? lock_id: 8552:45:3:2 lock_trx_id: 8552 ? lock_mode: X ? lock_type: RECORD ?lock_table: `ray`.`t` ?lock_index: PRIMARY ?lock_space: 45 ? lock_page: 3 ? ?lock_rec: 2 ? lock_data: 1 2 rows in set, 1 warning (0.00 sec) ERROR:? No query specified
綜合三張表查詢和show prcess fulllist得知,會話id 20(事務(wù)id 8552),鎖住了ray.t表,鎖模式是行級鎖,會話id 22(事務(wù)id 8553)的insert操作需要等待會話20釋放鎖后才能執(zhí)行,因此出現(xiàn)了會話id 22(事務(wù)id 8553)hang住現(xiàn)象。
解決方法,殺會話
mysql> kill 20; Query OK, 0 rows affected (0.00 sec)
當然,殺會話也可以通過pt-kill工具更方便,在后續(xù)文章會對pt-kill工具做詳細介紹
到此這篇關(guān)于MySQL鎖情況查看命令的文章就介紹到這了,更多相關(guān)MySQL鎖情況查看內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Windows環(huán)境下安裝MySQL 的教程圖解
這篇文章主要介紹了在Windows環(huán)境下安裝MySQL 的教程圖解,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
MySQL?移動數(shù)據(jù)目錄后啟動失敗問題解決
由于安裝數(shù)據(jù)庫時將MySQL的數(shù)據(jù)目錄放在了根目錄下,現(xiàn)在存儲空間不足,遇到這個問題如何解決呢,下面小編給大家?guī)砹薽ysql移動數(shù)據(jù)目錄啟動失敗解決方法,感興趣的朋友一起看看吧2023-04-04
mysql數(shù)據(jù)庫優(yōu)化總結(jié)(心得)
本篇文章是對mysql數(shù)據(jù)庫優(yōu)化進行了詳細的總結(jié)與介紹,需要的朋友參考下2013-06-06

