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

Mysql事物鎖等待超時Lock wait timeout exceeded;的解決

 更新時間:2022年03月01日 11:45:02   作者:程序新視界  
本文主要介紹了Mysql事物鎖等待超時Lock wait timeout exceeded;的解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

工作中同事遇到此異常,查找解決問題時,收集整理形成此篇文章。

問題場景

問題出現(xiàn)環(huán)境:
1、在同一事務(wù)內(nèi)先后對同一條數(shù)據(jù)進行插入和更新操作;
2、多臺服務(wù)器操作同一數(shù)據(jù)庫;
3、瞬時出現(xiàn)高并發(fā)現(xiàn)象;

不斷的有一下異常拋出,異常信息:

org.springframework.dao.CannotAcquireLockException: 
### Error updating database.  Cause: java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction
### The error may involve com.*.dao.mapper.PhoneFlowMapper.updateByPrimaryKeySelective-Inline
### The error occurred while setting parameters
### SQL:-----后面為SQL語句及堆棧信息-------- 

原因分析

在高并發(fā)的情況下,Spring事物造成數(shù)據(jù)庫死鎖,后續(xù)操作超時拋出異常。
Mysql數(shù)據(jù)庫采用InnoDB模式,默認參數(shù):innodb_lock_wait_timeout設(shè)置鎖等待的時間是50s,一旦數(shù)據(jù)庫鎖超過這個時間就會報錯。

解決方案

1、通過下面語句查找到為提交事務(wù)的數(shù)據(jù),kill掉此線程即可。

select * from information_schema.innodb_trx

2、增加鎖等待時間,即增大下面配置項參數(shù)值,單位為秒(s)

innodb_lock_wait_timeout=500

3、優(yōu)化存儲過程,事務(wù)避免過長時間的等待。

參考信息

1、鎖等待超時。是當前事務(wù)在等待其它事務(wù)釋放鎖資源造成的。可以找出鎖資源競爭的表和語句,優(yōu)化SQL,創(chuàng)建索引等。如果還是不行,可以適當減少并發(fā)線程數(shù)。

2、事務(wù)在等待給某個表加鎖時超時,估計是表正被另的進程鎖住一直沒有釋放。
可以用 SHOW INNODB STATUS/G; 看一下鎖的情況。

3、搜索解決之道,在管理節(jié)點的[ndbd default]區(qū)加:
TransactionDeadLockDetectionTimeOut=10000(設(shè)置 為10秒)默認是1200(1.2秒)

4、InnoDB會自動的檢測死鎖進行回滾,或者終止死鎖的情況。

InnoDB automatically detects transaction deadlocks and rolls back a transaction or transactions to break the deadlock. InnoDB tries to pick small transactions to roll back, where the size of a transaction is determined by the number of rows inserted, updated, or deleted.

如果參數(shù)innodb_table_locks=1并且autocommit=0時,InnoDB會留意表的死鎖,和MySQL層面的行級鎖。另外,InnoDB不會檢測MySQL的Lock Tables命令和其他存儲引擎死鎖。你應(yīng)該設(shè)置innodb_lock_wait_timeout來解決這種情況。
innodb_lock_wait_timeout是Innodb放棄行級鎖的超時時間。

參考文章:http://www.51testing.com/html/16/390216-838016.html

深入研究
由于此項目采用Spring+mybatis框架,事物控制采用“org.springframework.jdbc.datasource.DataSourceTransactionManager”類進行處理。此處還需進行進一步調(diào)研Spring實現(xiàn)的機制。

到此這篇關(guān)于Mysql事物鎖等待超時Lock wait timeout exceeded;的解決的文章就介紹到這了,更多相關(guān)Mysql事物鎖等待超時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL筆記之修改數(shù)據(jù)的解決方法

    MySQL筆記之修改數(shù)據(jù)的解決方法

    本篇文章介紹了,在mysql中修改數(shù)據(jù)的解決方法。需要的朋友參考下
    2013-05-05
  • mysql實現(xiàn)設(shè)置定時任務(wù)的方法分析

    mysql實現(xiàn)設(shè)置定時任務(wù)的方法分析

    這篇文章主要介紹了mysql實現(xiàn)設(shè)置定時任務(wù)的方法,結(jié)合實例形式分析了mysql定時任務(wù)相關(guān)的事件計劃設(shè)置與存儲過程使用等操作技巧,需要的朋友可以參考下
    2019-10-10
  • 淺談mysql通配符進行模糊查詢的實現(xiàn)方法

    淺談mysql通配符進行模糊查詢的實現(xiàn)方法

    這篇文章主要介紹了淺談mysql通配符進行模糊查詢,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • MySQL字符串函數(shù)詳解(推薦)

    MySQL字符串函數(shù)詳解(推薦)

    下面小編就為大家?guī)硪黄狹ySQL字符串函數(shù)詳解(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • MySQL權(quán)限控制和用戶與角色管理實例分析講解

    MySQL權(quán)限控制和用戶與角色管理實例分析講解

    用戶經(jīng)認證后成功登錄數(shù)據(jù)庫,之后服務(wù)器將通過系統(tǒng)權(quán)限表檢測用戶發(fā)出的每個請求操作,判斷用戶是否有足夠的權(quán)限來實施該操作,這就是MySQL的權(quán)限控制過程
    2022-12-12
  • mysql批量新增和存儲的方法實例

    mysql批量新增和存儲的方法實例

    這篇文章主要給大家介紹了關(guān)于mysql批量新增和存儲的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • 使用phpMyAdmin批量修改Mysql數(shù)據(jù)表前綴的方法

    使用phpMyAdmin批量修改Mysql數(shù)據(jù)表前綴的方法

    這篇文章主要介紹了使用phpMyAdmin批量修改Mysql數(shù)據(jù)表前綴的方法,需要的朋友可以參考下
    2015-09-09
  • mysql添加備注信息的實現(xiàn)

    mysql添加備注信息的實現(xiàn)

    這篇文章主要介紹了mysql添加備注信息的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • MySQL不同表之前的字段復(fù)制

    MySQL不同表之前的字段復(fù)制

    今天小編就為大家分享一篇關(guān)于MySQL不同表之前的字段復(fù)制,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • centos 6.9安裝mysql的詳細教程

    centos 6.9安裝mysql的詳細教程

    這篇文章主要介紹了centos 6.9安裝mysql的詳細教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-07-07

最新評論