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

mysql排查鎖等待的解決方法

 更新時間:2024年08月02日 09:08:28   作者:qq_42524262  
最近線上碰到了幾次mysql鎖等待的問題,本文主要介紹了mysql排查鎖等待的解決方法,具有一定的參考價值,感興趣的可以了解一下

排查鎖等待步驟

最近線上碰到了幾次mysql鎖等待的問題,一個事務線程長期占用鎖資源,導致其他事務無法獲取到鎖,為了快速解決問題,我們把線程kill掉了,但后面就定位不到具體的問題了,這里我總結整理一下我的方案。

如果事務剛好還處于等待狀態(tài)

  • 使用以下查詢查看具體的鎖等待情況,包括哪個事務持有了鎖,哪個事務在等待哪個鎖:
SELECT * FROM sys.innodb_lock_waits;

這里可以看到當前 鎖的類型,等待鎖的事務,等待時間

在這里插入圖片描述

同時我們可以看到等待的線程id,正在執(zhí)行的sql,但這個sql不全,我們可以拿這個線程id去
information_schema.PROCESSLIST 查到完整sql

在這里插入圖片描述

select * from information_schema.PROCESSLIST WHERE ID = 12;

這里我們還可以定位到執(zhí)行sql的host和端口

在這里插入圖片描述

但這些不是我們主要關注的,等待的事務超過時間會回滾,我們需要找到阻塞線程做了什么操作,還是回到第一步,找到阻塞線程id,但我們無法定位到具體sql,因為這里只會把正在執(zhí)行的sql查出來,所以如何找到阻塞線程執(zhí)行過的sql成了關鍵。

在這里插入圖片描述

  • 找到阻塞線程執(zhí)行過的sql

第一種:

前提是要打開 performance_schema,可以用下面sql看一下

SHOW VARIABLES LIKE 'performance_schema';

但注意,如果是OFF,改成ON的話需要重啟實例,一般線上環(huán)境是不會這么操作,而且打開后,因為要多記錄一些日志信息,會影響整體性能,也不推薦打開。

用阿里云的RDS,修改參數(shù)時也會提示

在這里插入圖片描述

查找阻塞線程的詳細信息:

SELECT * FROM performance_schema.threads WHERE processlist_id = 11;

在這里插入圖片描述

查看引起阻塞的SQL語句:

SELECT * FROM performance_schema.events_statements_history WHERE thread_id = 51;

這樣我們就定位到了該線程執(zhí)行過的sql,再通過information_schema.PROCESSLIST 找到host和port,去我們具體的服務定位問題。

在這里插入圖片描述

第二種方案:上面也提到performance_schema這個參數(shù)我們一般不會打開,所以我們只能通過事務id去binlog找了

1. 查詢binlog文件

首先,我們需要找到包含我們需要查詢的事務id的binlog文件??梢允褂靡韵旅畈榭串斍罢谏傻腷inlog文件

SHOW MASTER STATUS;

2.使用mysqlbinlog查找事務ID:接下來,可以使用mysqlbinlog命令配合–start-position和–stop-position參數(shù),逐步定位到含有特定事務ID的binlog記錄。但是直接通過事務ID查找可能不直接支持,因為通常事務ID并不直接暴露為查詢條件。一個更通用的方式是結合事務的時間戳或者其他上下文信息進行搜索。

如果你確切知道某個事務大致發(fā)生的時間,可以利用時間篩選,例如:

mysqlbinlog --start-datetime="2024-07-31 14:00:00" mysql-bin.000001 | grep "事務相關的關鍵詞或ID"

3.將binlog解析后的SQL語句輸出到一個文本文件中

mysqlbinlog mysql-bin.000001 > output.sql
mysqlbinlog --base64-output=DECODE-ROWS --verbose mysql-bin.000001 > output.sql

這樣就可以從輸出文件中找到我們事務的信息了

鎖等待事務已經(jīng)回滾

這種時候只能看看現(xiàn)在RUNNING的線程,看看是否像我們這種情況有事務長時間占用,通過事務id找到具體sql

SELECT * FROM information_schema.INNODB_TRX;

在這里插入圖片描述

到此這篇關于mysql排查鎖等待的解決方法的文章就介紹到這了,更多相關mysql排查鎖等待內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家! 

相關文章

  • 盡量避免使用索引合并的場景問題解析

    盡量避免使用索引合并的場景問題解析

    這篇文章主要為大家介紹了盡量避免使用索引合并的場景問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • MySql安裝與配置方法(MySQL添加用戶、刪除用戶與授權)

    MySql安裝與配置方法(MySQL添加用戶、刪除用戶與授權)

    這篇文章主要介紹了MySql安裝與配置方法(MySQL添加用戶、刪除用戶與授權)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • MySQL拋出Incorrect string value異常分析

    MySQL拋出Incorrect string value異常分析

    從上至下統(tǒng)一用上UTF-8就高枕無憂,今天還是遇到字符的異常,本文將介紹解決方法
    2012-11-11
  • Mysql通過ibd文件恢復數(shù)據(jù)的詳細步驟

    Mysql通過ibd文件恢復數(shù)據(jù)的詳細步驟

    mysql在使用的過程中,難免遇到數(shù)據(jù)庫表誤操作,下面這篇文章主要給大家介紹了關于Mysql通過ibd文件恢復數(shù)據(jù)的詳細步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • MySQL命令行中給表添加一個字段(字段名、是否為空、默認值)

    MySQL命令行中給表添加一個字段(字段名、是否為空、默認值)

    本文介紹MySQL數(shù)據(jù)庫使用SQL語句來在現(xiàn)有的表中,添加一個新的字段,包括設置字段的是否為空、默認值等
    2016-04-04
  • mysql利用覆蓋索引避免回表優(yōu)化查詢

    mysql利用覆蓋索引避免回表優(yōu)化查詢

    這篇文章主要給大家介紹了關于mysql如何利用覆蓋索引避免回表優(yōu)化查詢的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • Ubuntu 14.04下安裝MySQL

    Ubuntu 14.04下安裝MySQL

    1、更新源列表打開"終端窗口",輸入"sudo apt-getupdate"-->回車-->"輸入root用戶的密碼"-->回車,就可以了。如果不運行該命令,直接安裝mysql,會出現(xiàn)"有幾個軟件包無法下載,您可以運行apt-getupdate------"的錯誤提示,導致無法安裝。
    2016-04-04
  • 關于mysql 8.x 中insert ignore的性能問題

    關于mysql 8.x 中insert ignore的性能問題

    這篇文章主要介紹了關于mysql 8.x 中insert ignore的性能問題,具有很好的參考價值,希望對大家有所幫助。
    2022-08-08
  • Mysql基礎教程之增刪改查語句

    Mysql基礎教程之增刪改查語句

    這篇文章主要給大家介紹了關于Mysql基礎教程之增刪改查語句的相關資料,以下是MySQL最基本的增刪改查語句,很多IT工作者都必須要會的命令,也是IT行業(yè)面試最常考的知識點,需要的朋友可以參考下
    2023-10-10
  • 淺談慢SQL優(yōu)化之索引的作用

    淺談慢SQL優(yōu)化之索引的作用

    本文針對?MySQL?數(shù)據(jù)庫的?InnoDB?存儲引擎,介紹其中索引的實現(xiàn)以及索引在慢?SQL?優(yōu)化中的作用,本文主要討論不同場景下索引生效與失效的原因,感興趣的小伙伴可以跟著小編一起來探討
    2023-05-05

最新評論