Mysql错误: ERROR 1205: Lock wait timeout exceeded解决办法

MYSQL 报错:

SQLSTATE[HY000]: General error: 1205 Lock wait timeout exceeded; try restarting transaction

 

转载:https://my.oschina.net/quanzhong/blog/222091

 

  • 环境

    MySQL5.5 

  • 现象

    A.数据更新或新增后数据经常自动回滚。

    B.表操作总报 Lock wait timeout exceeded 并长时间无反应

  • 解决方法

    A.应急方法:show processlist; kill掉出现问题的进程

    B.根治方法:select * from innodb_trx 查看有是哪些事务占据了表资源。

        C.我的方法:设置MySQL锁等待超时 innodb_lock_wait_timeout=50 ,autocommit=on

  • 该类问题导致原因

    据我分析,Mysql的 InnoDB存储引擎是支持事务的,事务开启后没有被主动Commit。导致该资源被长期占用,其他事务在抢占该资源时,因上一个事务的锁而导致抢占失败!因此出现 Lock wait timeout exceeded 

 

 

网上搜索解决办法: 执行sql语句kill掉sleep状态的进程。

自己实践过可行:

 


/* 显示进程 */
show processlist;


/* kill掉进程 */

while :
do
n=`mysqladmin -uroot -p*** processlist | grep -i sleep | wc -l`
date=`date +%Y%m%d\[%H:%M:%S]`
echo $n
if [ "$n" -gt 10 ]
then
for i in `mysqladmin -uroot -p*** processlist | grep -i sleep | awk '{print $2}'`
do
mysqladmin -uroot -p*** kill $i
done
echo "sleep is too many i killed it" >> /root/tmp/sleep.log
echo "$date : $n" >> /root/tmp/sleep.log
fi
sleep 120 #每隔120 秒 执行一次

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值