关于MySQL出现lock wait timeout exceeded; try restarting transaction 的解决方案。

一、问题抛出

在做查询语句时,MySQL 抛出了这样的异常:

MySQL server error report:Array
([0] => Array([message] => MySQL Query Error)[1] => Array([sql] => SELECT * FROM taobao_trade WHERE order_status = 1 and orderID ='2018061812306547' AND is_tran_success=0 for update)[2] => Array([error] => Lock wait timeout exceeded; try restarting transaction)[3] => Array([errno] => 1205))

Lock wait timeout exceeded; try restarting transaction的异常,错误提示的意思,很明显,是因为这条语句被锁住了,所以释放这个锁。

二、解决方案

我们可以通过到information_schema 中来进行查找被锁的语句。

解释:information_schema这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面。

我们可以用下面三张表来查原因:

  • innodb_trx 当前运行的所有事务
  • innodb_locks 当前出现的锁
  • innodb_lock_waits 锁等待的对应关系

如果数据库中有锁的话,我们可以使用这条语句来查看:

select * from information_schema.innodb_trx

图中红色语句 LOCK WAIT为占用系统资源的语句,我们需要杀掉这个锁,执行 kill 线程id号。上面这条记录的id为199120823069, trx_mysql_thread_id 为 738178711, 所以我们执行:kill 738178711杀掉这个MySQL语句的线程即可。

执行之后:

kill 738178711// 查询线程
// SELECT * from information_schema.processlist WHERE id = 738178711;
// show full processlist;

其他的记录不需要关注,因为其他的记录状态为“RUNNING” 即正在执行的事务,并没有锁。

三、三张表字段说明

innodb_trx

desc information_schema.innodb_trx;

innodb_locks

desc information_schema.innodb_locks;

innodb_lock_waits

desc information_schema.innodb_lock_waits

四、终极方法

如果以上方法杀掉线程,但还是不能解决,则我们就可以查找执行线程用时比较久的用户,然后直接干掉。

SELECT * from information_schema.`PROCESSLIST` WHERE Time > 1000 AND USER = 'wonguser' ORDER BY TIME desc;kill 740097562

这样把所有耗时比较久的任务干掉,就可以解决这个问题了。

小结

关于我的那个问题,我通过这个方法 select * from information_schema.innodb_trx 已经杀掉了线程,但通过表直接修改那个id对应的数据,还是会弹出Lock wait timeout exceeded; try restarting transaction这样的异常,在网上找了许多未找出具体的解决方法,后来自己灵光一现,可以找出那些好事比较久的线程,然后把那些可疑的线程杀掉,没想到这个问题就解决了,可以正常对这行数据进行操作了。

原文:https://segmentfault.com/a/1190000015314171?utm_source=tag-newest

关于MySQL出现`lock wait timeout exceeded; try restarting transaction` 的解决方案相关推荐

  1. 关于MySQL出现锁等待lock wait timeout exceeded; try restarting transaction 的解决方案

    关于MySQL出现lock wait timeout exceeded; try restarting transaction 的解决方案. 一.问题抛出 在做查询语句时,MySQL 抛出了这样的异常 ...

  2. 排查mysql innodb Lock wait timeout exceeded; try restarting transaction的问题

    转载自:https://www.cnblogs.com/piperck/p/6212524.html OMG写的时候崩溃了一次. 触发关注这个问题的事情是 我们在使用pt-online-schedul ...

  3. 【MySQL】MySQL异常Lock wait timeout exceeded try restarting transaction

    遇到这个异常,还没尝试解决 https://blog.csdn.net/lingfeian/article/details/98312353

  4. mysql (1205, 'Lock wait timeout exceeded; try restarting transaction')

    1. show full processlist 2. kill <pid>

  5. mysql 中lock wait_应用中MYSQL 报错Lock wait timeout exceeded; try restarting transaction

    最近开发的应用开始做性能测试.在小于80用户并发的时候一切OK,并发量到100用户时,持续压5分钟.应用开始报错,并且只有1次错误,持续时间长,比如10分钟,会报3次. 日志如下: Caused by ...

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

    问题场景 问题出现环境: 1.在同一事务内先后对同一条数据进行插入和更新操作: 2.多台服务器操作同一数据库: 3.瞬时出现高并发现象: 不断的有一下异常抛出,异常信息: org.springfram ...

  7. mysql 锁 启动失败_关于mysql锁的错误Lock wait timeout exceeded; try restarting transaction 【求解】...

    2020-03-13 18:44:18 | INFO | http-nio-8085-exec-10 | com.newretail.hospital.controller.HAdviceContro ...

  8. MySQL -- Lock wait timeout exceeded; try restarting transaction参数控制

    Lock wait timeout exceeded; try restarting transaction 锁等待超时..回滚事务.. 当事务1  获得锁 start TRANSACTION upd ...

  9. 数据库 1205 Error 'Lock wait timeout exceeded; try restarting transaction' on query

    收到报警,mysql的从数据库在同步的过程出现问题,已停止同步. mysql> show slave status\G *************************** 1. row ** ...

最新文章

  1. bilibili怎么设置弹幕数量_python爬取B站视频弹幕分析并制作词云
  2. 「ImageProcess」mp4视频转存图片内存变大的原因探究
  3. oracle中的greatest,ORACLE 内置函数之 GREATEST 和 LEAST(转)
  4. 这个时代,给了我们年轻人太多
  5. 剑指offer-3(替换空格)
  6. win10下如何安装vb6.0sp6_Mac如何安装win10系统?Parallels Desktop 15 Mac安装win10系统教程...
  7. 将mysql中的数据库表导出和导入
  8. 系统运维哪些事儿之正常状态
  9. matlab xrd,波导光学大作业-论文-matlab模拟xrd及分析.doc
  10. python word转pdf linux_在Linux系统中把Pdf转化成word文档的软件
  11. 个人中心网页设计html,超全面!个人中心页面从思考到设计全过程
  12. python判断火车票座位_用Python实现火车票查询(含票价版)
  13. postman与fiddler
  14. 阿里云二级域名配置-ssl证书包不安全问题记录
  15. 漏洞分析:MS12-020漏洞
  16. 不敢说最快!但是这款CRAS C700绝对是我们见过最漂亮的SSD
  17. 所有计算机用户的共同点,2016年职称计算机WindowsXP考前押题及答案3
  18. drupal mysql配置文件_安装和配置Drupal 8教程,如何安装和配置Drupal 8?
  19. web服务器软件:Tomcat入门(window安装和配置Tomcat)
  20. 第23课 Altium Designer20(AD20)+VESC6.4实战教程:导入嘉立创原理图 增加PCB信号层 差分线计算和走线方法(北冥有鱼

热门文章

  1. 【Python基础】GitHub 星标 8.8w+,Python 小白 100 天学习计划,从新手到大师!
  2. 一文讲解自动机器学习(AutoML)!
  3. 图像算法处理视频不稳定?港科大团队提出一种通用算法解决视频处理时域不稳定问题
  4. 搜索算法相似度问题之BM25
  5. 云信小课堂丨简单四步,快速搭建协同办公系统!
  6. 数据结构+算法——错题总结
  7. Java_案例实例1.简单的人机交互
  8. 开博 即便网络工程师真的没落了,兴趣不是最重要的么?
  9. 今年618我要Pick有很吓人技术GPU TURBO的手机,你呢?
  10. 如何多快好省的建设企业级呼叫中心(一)