欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文教你學(xué)會定位線上MySQL鎖超時問題

 更新時間:2022年08月16日 10:30:31   作者:一燈架構(gòu)  
這篇文章主要介紹了一文教你學(xué)會定位線上MySQL鎖超時問題,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言:

昨晚我正在床上睡得著著的,突然來了一條短信。

什么?線上的訂單無法取消!

我趕緊登錄線上系統(tǒng),查看業(yè)務(wù)日志。

發(fā)現(xiàn)有MySQL鎖超時的錯誤日志。

不用想,肯定有另一個事務(wù)正在修改這條訂單,持有這條訂單的鎖。

導(dǎo)致當(dāng)前事務(wù)獲取不到鎖,一直等待,直到超過鎖超時時間,然后報錯。

既然問題已經(jīng)清楚了,接下來就輪到怎么排查一下到底是哪個事務(wù)正在持有這條訂單的鎖。

好在MySQL提供了豐富的工具,幫助我們排查鎖競爭問題。

現(xiàn)場復(fù)現(xiàn)一個這個問題:

創(chuàng)建一張用戶表,造點數(shù)據(jù):

CREATE TABLE `user` (
 ?`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵ID',
 ?`name` varchar(50) NOT NULL DEFAULT '' COMMENT '姓名',
 ?PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

事務(wù)1,更新id=1的用戶姓名,不提交事務(wù):

begin;
update user set name='一燈' where id=1;

事務(wù)2,刪除id=1的數(shù)據(jù),這時候會產(chǎn)生鎖等待:

begin;
delete from user where id=1;

接下來,我們就通過MySQL提供的鎖競爭統(tǒng)計表,排查一下鎖等待問題:

先查一下鎖等待情況:

select * from information_schema.innodb_lock_waits;

可以看到有一個鎖等待的事務(wù)。

然后再查一下正在競爭的鎖有哪些?

select * from information_schema.innodb_locks;

可以看到,MySQL統(tǒng)計的非常詳細:

lock_trx_id 表示事務(wù)ID

lock_mode 表示排它鎖還是共享鎖

lock_type 表示鎖定的記錄,還是范圍

lock_table 鎖的表名

lock_index 鎖定的是主鍵索引

再查一下正在執(zhí)行的事務(wù)有哪些?

select * from information_schema.innodb_trx; 

可以清楚的看到正在執(zhí)行的事務(wù)有兩個,一個狀態(tài)是鎖等待(LOCK WAIT),正在執(zhí)行的SQL也打印出來了:

delete from user where id=1;

正是事務(wù)2的刪除語句。

不用問,第二條,顯示正在運行狀態(tài)(RUNNING)的事務(wù)就是正在持有鎖的事務(wù)1,MySQL線程id(trx_mysql_thread_id)是193。

我們用MySQL線程id查一下事務(wù)線程id:

select * from performance_schema.threads where processlist_id=193;

找到對應(yīng)的事務(wù)線程id是218,然后再找一下這個線程正在執(zhí)行的SQL語句:

select THREAD_ID,CURRENT_SCHEMA,SQL_TEXT 
from performance_schema.events_statements_current 
where thread_id=218;

可以清楚的看到這個線程正在執(zhí)行的SQL語句就是事務(wù)1的update語句。

持有鎖的SQL語句找到了,接下來再去找對應(yīng)的業(yè)務(wù)代碼也就輕而易舉了。

以上是基于MySQL5.7版本,在MySQL8.0版本中有些命令已經(jīng)刪除了,替換成了其他命令,下篇文章再講一下MySQL8.0怎么定位MySQL鎖超時問題。

到此這篇關(guān)于一文教你學(xué)會定位線上MySQL鎖超時問題的文章就介紹到這了,更多相關(guān)MySQL鎖超時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL 8.0.20 Window10免安裝版配置及Navicat管理教程圖文詳解

    MySQL 8.0.20 Window10免安裝版配置及Navicat管理教程圖文詳解

    這篇文章主要介紹了MySQL 8.0.20 Window10免安裝版配置及Navicat管理,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 完美解決phpstudy安裝后mysql無法啟動(無需刪除原數(shù)據(jù)庫,無需更改任何配置,無需更改端口)直接共存

    完美解決phpstudy安裝后mysql無法啟動(無需刪除原數(shù)據(jù)庫,無需更改任何配置,無需更改端口)直接共存

    這篇文章主要介紹了完美解決phpstudy安裝后mysql無法啟動(無需刪除原數(shù)據(jù)庫,無需更改任何配置,無需更改端口)直接共存 ,需要的朋友可以參考下
    2019-04-04
  • MySQL數(shù)據(jù)庫終端—常用操作指令代碼

    MySQL數(shù)據(jù)庫終端—常用操作指令代碼

    這篇文章主要介紹了MySQL數(shù)據(jù)庫終端—常用操作指令代碼,添加用戶、更改用戶名和host主機、更改密碼、刪除用戶等等,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-01-01
  • 徹底卸載mysql 個人親測!

    徹底卸載mysql 個人親測!

    這篇文章主要為大家詳細介紹了徹底卸載mysql的具體步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Mysql基礎(chǔ)教程之增刪改查語句

    Mysql基礎(chǔ)教程之增刪改查語句

    這篇文章主要給大家介紹了關(guān)于Mysql基礎(chǔ)教程之增刪改查語句的相關(guān)資料,以下是MySQL最基本的增刪改查語句,很多IT工作者都必須要會的命令,也是IT行業(yè)面試最??嫉闹R點,需要的朋友可以參考下
    2023-10-10
  • centos6.5下mysql 5.7.19 安裝配置方法

    centos6.5下mysql 5.7.19 安裝配置方法

    這篇文章主要為大家詳細介紹了centos6.5下mysql 5.7.19 安裝配置方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 如何在mysql進行查詢緩存及失敗的解決方法

    如何在mysql進行查詢緩存及失敗的解決方法

    這篇文章主要介紹了如何在mysql進行查詢緩存及失敗的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • MySQL常用分庫分表方案匯總

    MySQL常用分庫分表方案匯總

    本文主要介紹了MySQL常用分庫分表方案匯總,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • MySQL優(yōu)化案例系列-mysql分頁優(yōu)化

    MySQL優(yōu)化案例系列-mysql分頁優(yōu)化

    這篇文章主要介紹了MySQL優(yōu)化案例系列-mysql分頁優(yōu)化,需要的朋友可以參考下
    2016-08-08
  • MySQL主從復(fù)制之GTID模式詳細介紹?

    MySQL主從復(fù)制之GTID模式詳細介紹?

    這篇文章主要介紹了MySQL主從復(fù)制之GTID模式,GTID的復(fù)制方式,它由UUID和事務(wù)ID兩個部分組成,具有GTID事務(wù)是全局唯一性的,并且一個事務(wù)對應(yīng)一個GTID值、一個GTID值在同一個MySQL實例上只會執(zhí)行一次等特點,想了解更多的小伙伴可以參考下面詳細內(nèi)容,希望對你有所幫助
    2022-02-02

最新評論