问题1:线上mysql更新报错
Update All error:【SQLSTATE[HY000]: General error: 1205 Lock wait timeout exceeded; try restarting transaction
The SQL being executed was: UPDATE `amz_email` SET `is_read`=1 WHERE `id`='28785'】
一开始发现是int => sting 未走索引引起来,于是调整SQL为
UPDATE `amz_email` SET `solved_type`=2, `response_needed`=0, `as_status`=1 WHERE `id`=28773
系统继续报错
Update All error:【SQLSTATE[HY000]: General error: 1205 Lock wait timeout exceeded; try restarting transaction
The SQL being executed was: UPDATE `amz_email` SET `solved_type`=2, `response_needed`=0, `as_status`=1 WHERE `id`=28773】
一 查看innodb的锁 显示正常
select * from information_schema.innodb_locks
data:image/s3,"s3://crabby-images/48cd7/48cd7fc4f70a64e197bfdded95590928d5dbf56b" alt=""
二 查看事务提交情况
select * from information_schema.INNODB_TRX; 发现有条件事务一直未提交
data:image/s3,"s3://crabby-images/49709/49709ef547a930ebdf0cc84b15fb3ab1beb99fa2" alt=""
三 查看show PROCESSLIST;发货12956643这条回话状态为sleep状态
data:image/s3,"s3://crabby-images/4a3c7/4a3c7eb84b5efb2b98020733654fab054f2e4c54" alt=""
kill 12956643 这条会话 服务恢复正常
网友评论