日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql死锁释放时间参数_【Mysql】mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法...

發(fā)布時間:2023/12/20 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql死锁释放时间参数_【Mysql】mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

問題場景

問題出現(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語句及堆棧信息--------

1

2

3

4

5

原因分析

在高并發(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

1

主要看著幾個字段,如果有阻塞數(shù)據(jù)就不是0,找到后在根據(jù)下圖這個字段殺死進程

kill ? id ?;(殺死對應(yīng)id的進程)

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

innodb_lock_wait_timeout=500

1

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

參考信息

1、鎖等待超時。是當前事務(wù)在等待其它事務(wù)釋放鎖資源造成的??梢哉页鲦i資源競爭的表和語句,優(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放棄行級鎖的超時時間。

深入研究

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

總結(jié)

以上是生活随笔為你收集整理的mysql死锁释放时间参数_【Mysql】mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。