关于MySQL出现锁等待lock wait timeout exceeded; try restarting transaction 的解决方案
关于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 的解决方案相关推荐
- 关于MySQL出现`lock wait timeout exceeded; try restarting transaction` 的解决方案
关于MySQL出现lock wait timeout exceeded; try restarting transaction 的解决方案. 一.问题抛出 在做查询语句时,MySQL 抛出了这样的异常 ...
- Lock wait timeout exceeded; try restarting transaction
排查过程: 查看数据库 INNODB_LOCKS,未发现有死锁的记录. 查看 SHOW PROCESSLIST; 也未见异常进程: 通过Mysql的控制台,查询慢日志,也未找到有关此表的Mysql慢日 ...
- mysql死锁,等待资源,事务锁,Lock wait timeout exceeded; try restarting
2019独角兽企业重金招聘Python工程师标准>>> 项目遇到一个问题,使用过程查询某表的时候 SELECTifnull(sum(total),0) FROM order 卡主了, ...
- 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 ...
- mysql死锁释放时间参数_【Mysql】mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法...
问题场景 问题出现环境: 1.在同一事务内先后对同一条数据进行插入和更新操作: 2.多台服务器操作同一数据库: 3.瞬时出现高并发现象: 不断的有一下异常抛出,异常信息: org.springfram ...
- 排查mysql innodb Lock wait timeout exceeded; try restarting transaction的问题
转载自:https://www.cnblogs.com/piperck/p/6212524.html OMG写的时候崩溃了一次. 触发关注这个问题的事情是 我们在使用pt-online-schedul ...
- mysql 中lock wait_应用中MYSQL 报错Lock wait timeout exceeded; try restarting transaction
最近开发的应用开始做性能测试.在小于80用户并发的时候一切OK,并发量到100用户时,持续压5分钟.应用开始报错,并且只有1次错误,持续时间长,比如10分钟,会报3次. 日志如下: Caused by ...
- MySQL -- Lock wait timeout exceeded; try restarting transaction参数控制
Lock wait timeout exceeded; try restarting transaction 锁等待超时..回滚事务.. 当事务1 获得锁 start TRANSACTION upd ...
- java lock wait_java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction
在开发测试过程中发现出了这个问题: RECHARGE:业务,数据: {"platformUserNo":"RPD_1512632756191","am ...
最新文章
- 假期怎么提升Python技能?100+编程题给你练~
- Python机器学习(三)--决策树算法
- 如何处理 Hybris Accelerator css style 显示不正确的问题
- 【渝粤题库】陕西师范大学300011 历史文献学
- android media apex_APEX英雄主播即将登陆时代广场?人气十强介绍!
- centos7无法使用epel的解决方法
- python 接口测试 如何写配置文件_python接口自动化测试 - configparser配置文件解析器详细使用...
- 字符串匹配——BMH算法
- 文档服务器备份吗,本地资料和云服务器备份吗
- 2022年IT热门能力
- jq真正清空表单数据(亲测 好用)
- html5媒体查询的特点,巧妙使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的好方法...
- 数据库学习资料和视频
- lingo12软件下载及lingo语言入门资源
- 滴滴打车CTO张博:下一阶段重点机器学习
- Bibtex 参考文献样式
- tpc1061ti使用说明_TPC1061TiMCGS昆仑通态人机界面触摸屏HMI
- 查找算法【平衡二叉树】 - 平衡二叉树的删除
- 2018“人工智能”:是彻底复苏?还是起落轮回?| 抢票
- Coin-row problem
热门文章
- 【Python基础】嵌套 JSON 秒变 Dataframe!
- 【论文解读】从BERT和XLNet到MPNet
- 【CV】54篇最新CV领域综述论文速递!涵盖14个方向:目标检测/图像分割/医学影像/人脸识别等方向...
- 李沐《动手学深度学习》新增PyTorch和TensorFlow实现,还有中文版
- Spark性能优化 -- Spark SQL、DataFrame、Dataset
- 心路历程:「双非」研究生数据分析春招
- 史上最全python字符串操作指南
- 自注意力真的是Transformer的必杀技吗?MSRA否认三连,并反手给你扔来一个sMLPNet
- 不忘每份支持,网易云信感谢一路有你
- CSDN专访云信阙杭宁:以16年技术积累打造稳定IM云服务