MySQL鎖情況查看命令
本文介紹如何在MySQL數(shù)據(jù)庫(kù)中分析鎖的情況及處理思路。
MySQL版本
mysql> select version(); +------------+ | version() | +------------+ | 5.7.38-log | +------------+ 1 row in set (0.01 sec)
模擬鎖產(chǎn)生
A會(huì)話(huà)加鎖
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會(huì)話(huà)插入數(shù)據(jù),造成鎖等待現(xiàn)象
mysql> insert into t values(0,'null');
這里介紹MySQL查看鎖的3個(gè)數(shù)據(jù)字典表,分別是位于information_schema數(shù)據(jù)庫(kù)下的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號(hào),本次測(cè)試中是8552和8553
trx_state:當(dāng)前事務(wù)的狀態(tài),本次測(cè)試中8553是LOCK WAIT 鎖等待狀態(tài)
trx_wait_started:事務(wù)開(kāi)始等待時(shí)間,本次測(cè)試中為2022-12-14 16:52:29
trx_mysql_thread_id:線(xiàn)程id,與show full processlist中的id對(duì)應(yīng),本次測(cè)試中為22
trx_query:事務(wù)運(yùn)行的SQL語(yǔ)句,本次測(cè)試為insert into t values(0,‘null’)
trx_operation_state:事務(wù)運(yùn)行的狀態(tài),本次測(cè)試為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:請(qǐng)求鎖的事務(wù)id,本次測(cè)試為8553
blocking_trx_id:持有鎖的事務(wù)id,也就是造成鎖等待的事務(wù)id,本次測(cè)試為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
綜合三張表查詢(xún)和show prcess fulllist得知,會(huì)話(huà)id 20(事務(wù)id 8552),鎖住了ray.t表,鎖模式是行級(jí)鎖,會(huì)話(huà)id 22(事務(wù)id 8553)的insert操作需要等待會(huì)話(huà)20釋放鎖后才能執(zhí)行,因此出現(xiàn)了會(huì)話(huà)id 22(事務(wù)id 8553)hang住現(xiàn)象。
解決方法,殺會(huì)話(huà)
mysql> kill 20; Query OK, 0 rows affected (0.00 sec)
當(dāng)然,殺會(huì)話(huà)也可以通過(guò)pt-kill工具更方便,在后續(xù)文章會(huì)對(duì)pt-kill工具做詳細(xì)介紹
到此這篇關(guān)于MySQL鎖情況查看命令的文章就介紹到這了,更多相關(guān)MySQL鎖情況查看內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解MySQL查看執(zhí)行慢的SQL語(yǔ)句(慢查詢(xún))
查看執(zhí)行慢的SQL語(yǔ)句,需要先開(kāi)啟慢查詢(xún)?nèi)罩?,MySQL的慢查詢(xún)?nèi)罩?,記錄在MySQL中響應(yīng)時(shí)間超過(guò)閥值的語(yǔ)句(具體指運(yùn)行時(shí)間超過(guò)long_query_time值的SQL,本文給大家介紹MySQL查看執(zhí)行慢的SQL語(yǔ)句,感興趣的朋友跟隨小編一起看看吧2024-03-03MySQL中的datediff()方法和timestampdiff()方法的應(yīng)用示例小結(jié)
在MySQL中,DATEDIFF()函數(shù)和TIMESTAMPDIFF()函數(shù)用于計(jì)算日期和時(shí)間之間的差異,TIMESTAMPDIFF()函數(shù)返回的結(jié)果是整數(shù),但你可以通過(guò)在計(jì)算過(guò)程中使用適當(dāng)?shù)某▉?lái)獲得所需的小數(shù)部分,本文介紹MySQL中的datediff()方法和timestampdiff()方法的應(yīng)用,感興趣的朋友一起看看吧2023-12-12MySQL查詢(xún)時(shí)指定使用索引的實(shí)現(xiàn)
在MySQL中,可以通過(guò)指定查詢(xún)使用的索引來(lái)提高查詢(xún)性能和優(yōu)化查詢(xún)執(zhí)行計(jì)劃,本文就來(lái)介紹一下MySQL查詢(xún)時(shí)指定使用索引的實(shí)現(xiàn),感興趣的可以了解一下2023-11-11根據(jù)status信息對(duì)MySQL服務(wù)器進(jìn)行優(yōu)化
網(wǎng)上有很多的文章教怎么配置MySQL服務(wù)器,但考慮到服務(wù)器硬件配置的不同,具體應(yīng)用的差別,那些文章的做法只能作為初步設(shè)置參考,我們需要根據(jù)自己的情況進(jìn)行配置優(yōu)化,好的做法是MySQL服務(wù)器穩(wěn)定運(yùn)行了一段時(shí)間后運(yùn)行,根據(jù)服務(wù)器的”狀態(tài)”進(jìn)行優(yōu)化。2011-09-09mysql如何通過(guò)當(dāng)前排序字段獲取相鄰數(shù)據(jù)項(xiàng)
這篇文章主要介紹了mysql如何通過(guò)當(dāng)前排序字段獲取相鄰數(shù)據(jù)項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05