关于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. Lock wait timeout exceeded; try restarting transaction

    排查过程: 查看数据库 INNODB_LOCKS,未发现有死锁的记录. 查看 SHOW PROCESSLIST; 也未见异常进程: 通过Mysql的控制台,查询慢日志,也未找到有关此表的Mysql慢日 ...

  3. mysql死锁,等待资源,事务锁,Lock wait timeout exceeded; try restarting

    2019独角兽企业重金招聘Python工程师标准>>> 项目遇到一个问题,使用过程查询某表的时候 SELECTifnull(sum(total),0) FROM order 卡主了, ...

  4. 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 ...

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

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

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

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

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

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

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

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

  9. java lock wait_java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction

    在开发测试过程中发现出了这个问题: RECHARGE:业务,数据: {"platformUserNo":"RPD_1512632756191","am ...

最新文章

  1. 假期怎么提升Python技能?100+编程题给你练~
  2. Python机器学习(三)--决策树算法
  3. 如何处理 Hybris Accelerator css style 显示不正确的问题
  4. 【渝粤题库】陕西师范大学300011 历史文献学
  5. android media apex_APEX英雄主播即将登陆时代广场?人气十强介绍!
  6. centos7无法使用epel的解决方法
  7. python 接口测试 如何写配置文件_python接口自动化测试 - configparser配置文件解析器详细使用...
  8. 字符串匹配——BMH算法
  9. 文档服务器备份吗,本地资料和云服务器备份吗
  10. 2022年IT热门能力
  11. jq真正清空表单数据(亲测 好用)
  12. html5媒体查询的特点,巧妙使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的好方法...
  13. 数据库学习资料和视频
  14. lingo12软件下载及lingo语言入门资源
  15. 滴滴打车CTO张博:下一阶段重点机器学习
  16. Bibtex 参考文献样式
  17. tpc1061ti使用说明_TPC1061TiMCGS昆仑通态人机界面触摸屏HMI
  18. 查找算法【平衡二叉树】 - 平衡二叉树的删除
  19. 2018“人工智能”:是彻底复苏?还是起落轮回?| 抢票
  20. Coin-row problem

热门文章

  1. 【Python基础】嵌套 JSON 秒变 Dataframe!
  2. 【论文解读】从BERT和XLNet到MPNet
  3. 【CV】54篇最新CV领域综述论文速递!涵盖14个方向:目标检测/图像分割/医学影像/人脸识别等方向...
  4. 李沐《动手学深度学习》新增PyTorch和TensorFlow实现,还有中文版
  5. Spark性能优化 -- Spark SQL、DataFrame、Dataset
  6. 心路历程:「双非」研究生数据分析春招
  7. 史上最全python字符串操作指南
  8. 自注意力真的是Transformer的必杀技吗?MSRA否认三连,并反手给你扔来一个sMLPNet
  9. 不忘每份支持,网易云信感谢一路有你
  10. CSDN专访云信阙杭宁:以16年技术积累打造稳定IM云服务