关于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 抛出了这样的异常 ...
- 排查mysql innodb Lock wait timeout exceeded; try restarting transaction的问题
转载自:https://www.cnblogs.com/piperck/p/6212524.html OMG写的时候崩溃了一次. 触发关注这个问题的事情是 我们在使用pt-online-schedul ...
- 【MySQL】MySQL异常Lock wait timeout exceeded try restarting transaction
遇到这个异常,还没尝试解决 https://blog.csdn.net/lingfeian/article/details/98312353
- mysql (1205, 'Lock wait timeout exceeded; try restarting transaction')
1. show full processlist 2. kill <pid>
- mysql 中lock wait_应用中MYSQL 报错Lock wait timeout exceeded; try restarting transaction
最近开发的应用开始做性能测试.在小于80用户并发的时候一切OK,并发量到100用户时,持续压5分钟.应用开始报错,并且只有1次错误,持续时间长,比如10分钟,会报3次. 日志如下: Caused by ...
- mysql死锁释放时间参数_【Mysql】mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法...
问题场景 问题出现环境: 1.在同一事务内先后对同一条数据进行插入和更新操作: 2.多台服务器操作同一数据库: 3.瞬时出现高并发现象: 不断的有一下异常抛出,异常信息: org.springfram ...
- 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 -- Lock wait timeout exceeded; try restarting transaction参数控制
Lock wait timeout exceeded; try restarting transaction 锁等待超时..回滚事务.. 当事务1 获得锁 start TRANSACTION upd ...
- 数据库 1205 Error 'Lock wait timeout exceeded; try restarting transaction' on query
收到报警,mysql的从数据库在同步的过程出现问题,已停止同步. mysql> show slave status\G *************************** 1. row ** ...
最新文章
- bilibili怎么设置弹幕数量_python爬取B站视频弹幕分析并制作词云
- 「ImageProcess」mp4视频转存图片内存变大的原因探究
- oracle中的greatest,ORACLE 内置函数之 GREATEST 和 LEAST(转)
- 这个时代,给了我们年轻人太多
- 剑指offer-3(替换空格)
- win10下如何安装vb6.0sp6_Mac如何安装win10系统?Parallels Desktop 15 Mac安装win10系统教程...
- 将mysql中的数据库表导出和导入
- 系统运维哪些事儿之正常状态
- matlab xrd,波导光学大作业-论文-matlab模拟xrd及分析.doc
- python word转pdf linux_在Linux系统中把Pdf转化成word文档的软件
- 个人中心网页设计html,超全面!个人中心页面从思考到设计全过程
- python判断火车票座位_用Python实现火车票查询(含票价版)
- postman与fiddler
- 阿里云二级域名配置-ssl证书包不安全问题记录
- 漏洞分析:MS12-020漏洞
- 不敢说最快!但是这款CRAS C700绝对是我们见过最漂亮的SSD
- 所有计算机用户的共同点,2016年职称计算机WindowsXP考前押题及答案3
- drupal mysql配置文件_安装和配置Drupal 8教程,如何安装和配置Drupal 8?
- web服务器软件:Tomcat入门(window安装和配置Tomcat)
- 第23课 Altium Designer20(AD20)+VESC6.4实战教程:导入嘉立创原理图 增加PCB信号层 差分线计算和走线方法(北冥有鱼