lock wait timeout exceeded; try restarting transactio解决方案

原创 2017年05月25日 17:10:38

问题原因:
       今天线上环境,突然出现一个问题,追踪原因是数据库中的一条语句报错,错误内容:
lock wait timeout exceeded; try restarting transactio
       执行update table set status = 1 where id = 10002;是可以的。
       而执行update table set status = 1 where id = 10001;这条语句执行失败。
       错误提示的意思,很明显,是因为这条语句被锁住了。所以释放这个锁。

       
解决方案:
       新创建的数据库,是这样子的:
       新创建的数据库结构
       
       现在我们要查test库中使用情况,我们可以到information_schema中查询
       解释:information_schema这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面。

我们可以用下面三张表来查原因:
       innodb_trx ## 当前运行的所有事务
       innodb_locks ## 当前出现的锁
       innodb_lock_waits ## 锁等待的对应关系

       
如果数据库中有锁的话,那么在
查询当前运行的事务
       
       图中红色语句为占用系统资源的语句,我们需要杀掉这个锁,执行 kill 线程id号。上面这条记录的id为319618246
所以我们执行:kill 319618246即可
执行之后:
执行之后
       
其他的记录不需要关注,因为其他的记录状态为“RUNNING” 即正在执行的事务,并没有锁。。

       我们可以进一步了解一下 那三张表的表结构:

desc information_schema.innodb_locks;

Field Type Null Key Default Remark
lock_id varchar(81) NO 锁ID
lock_trx_id varchar(18) NO 拥有锁的事务ID
lock_mode varchar(32) NO 锁模式
lock_type varchar(32) NO 锁类型
lock_table varchar(1024) NO 被锁的表
lock_index varchar(1024) YES NULL 被锁的索引
lock_space bigint(21) unsigned YES NULL 被锁的表空间号
lock_page bigint(21) unsigned YES NULL 被锁的页号
lock_rec bigint(21) unsigned YES NULL 被锁的记录号
lock_data varchar(8192) YES NULL 被锁的数据

desc information_schema.innodb_lock_waits

Field Type Null Key Default Remark
requesting_trx_id varchar(18) NO 请求锁的事务ID
requested_lock_id varchar(81) NO 请求锁的锁ID
blocking_trx_id varchar(18) NO 当前拥有锁的事务ID
blocking_lock_id varchar(81) NO 当前拥有锁的锁ID

desc information_schema.innodb_trx ;

Field Type Null Key Default Extra Remark
trx_id varchar(18) NO 事务ID
trx_state varchar(13) NO 事务状态:
trx_started datetime NO 0000-00-00 00:00:00 事务开始时间;
trx_requested_lock_id varchar(81) YES NULL innodb_locks.lock_id
trx_wait_started datetime YES NULL 事务开始等待的时间
trx_weight bigint(21) unsigned NO 0 #
trx_mysql_thread_id bigint(21) unsigned NO 0 事务线程ID
trx_query varchar(1024) YES NULL 具体SQL语句
trx_operation_state varchar(64) YES NULL 事务当前操作状态
trx_tables_in_use bigint(21) unsigned NO 0 事务中有多少个表被使用
trx_tables_locked bigint(21) unsigned NO 0 事务拥有多少个锁
trx_lock_structs bigint(21) unsigned NO 0 #
trx_lock_memory_bytes bigint(21) unsigned NO 0 事务锁住的内存大小(B)
trx_rows_locked bigint(21) unsigned NO 0 事务锁住的行数
trx_rows_modified bigint(21) unsigned NO 0 事务更改的行数
trx_concurrency_tickets bigint(21) unsigned NO 0 事务并发票数
trx_isolation_level varchar(16) NO 事务隔离级别
trx_unique_checks int(1) NO 0 是否唯一性检查
trx_foreign_key_checks int(1) NO 0 是否外键检查
trx_last_foreign_key_error varchar(256) YES NULL 最后的外键错误
trx_adaptive_hash_latched int(1) NO 0 #
trx_adaptive_hash_timeout bigint(21) unsigned NO 0 #
版权声明:本文为博主原创文章,未经博主允许不得转载。

lock wait timeout exceeded; try restarting transactio解决方案

问题原因:        今天线上环境,突然出现一个问题,追踪原因是数据库中的一条语句报错,错误内容: lock wait timeout exceeded; try restarting tra...
  • zc474235918
  • zc474235918
  • 2017年05月25日 17:10
  • 7491

‘lock wait timeout exceeded; try restarting transaction’解决方案

执行sql 插入语句,出现 lock wait timeout exceeded; try restarting transaction报错。
  • uknow0904
  • uknow0904
  • 2018年01月16日 21:51
  • 53

MySQL:关于Lock wait timeout exceeded; try restarting transaction

1、锁等待超时。是当前事务在等待其它事务释放锁资源造成的。可以找出锁资源竞争的表和语句,优化你的SQL,创建索引等,如果还是不行,可以适当减少并发线程数。 2、你的事务在等待给某个表加锁时超时了...
  • xxssyyyyssxx
  • xxssyyyyssxx
  • 2016年08月23日 15:58
  • 2677

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction的问题解决(备忘)

今天让运维将测试库的数据到了导出一份到自己电脑本地来做测试,数据量较大(几百万条吧),系统运行起来之后查看订单列表数据很慢(估计是自己电脑配置太low了,刷新列表的时候一直在加载),然后就想删除部分数...
  • mayor125
  • mayor125
  • 2017年07月27日 15:10
  • 1599

Mysql事物锁等待超时 Lock wait timeout exceeded; try restarting transaction

工作中同事遇到此异常,查找解决问题时,收集整理形成此篇文章。问题场景问题出现环境: 1、在同一事务内先后对同一条数据进行插入和更新操作; 2、多台服务器操作同一数据库; 3、瞬时出现高并发现象;...
  • wo541075754
  • wo541075754
  • 2016年02月22日 16:50
  • 26145

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

前言:朋友咨询我说执行简单的update语句失效,症状如下:mysql> update order_info  set province_id=15  ,city_id= 1667  where or...
  • mchdba
  • mchdba
  • 2014年07月31日 10:59
  • 55913

mysql异常Lock wait timeout exceeded; try restarting transaction

mysql中使用update语句更新数据报错: Lock wait timeout exceeded; try restarting transaction。 这是因为你要更新的表的锁在其他线程手里,...
  • w171203757
  • w171203757
  • 2015年08月19日 19:40
  • 2692

mysql的gap锁导致Lock wait timeout exceeded try restarting transaction异常

问题: 今天同事碰到了在mysql对表进行insert的时候报Lock wait timeout exceeded try restarting transaction的异常,在这里记录一下。 原因是...
  • sanniao
  • sanniao
  • 2016年08月04日 21:50
  • 1122

关于MYSQL ERROR 1205 :Lock wait timeout exceeded; try restarting transaction

在mysql的数据库上操作增删改查语句,数据库一直在执行,响应完后,报Lock wait timeout exceeded;try restarting transaction; 执行delete语句...
  • Hayley_Liu
  • Hayley_Liu
  • 2016年10月07日 18:58
  • 2074

[Err] 1205 - Lock wait timeout exceeded; try restarting transaction

修改表 BEGIN; INSERT into op_log(uuid,opname,ip,source,created) values('8b9457d7-abfd-4cc0-b7e2-d33a9...
  • zhangxihangzhuan
  • zhangxihangzhuan
  • 2015年12月23日 16:10
  • 1560
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:lock wait timeout exceeded; try restarting transactio解决方案
举报原因:
原因补充:

(最多只允许输入30个字)