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

1、4个用户连接数据库(A和D是本地回环登陆,B和C是本地登陆)

A用户信息:
    mysql> status;
    --------------
    Connection id:        8
    Current database:    db1
    Current user:        root@localhost
    Connection:            127.0.0.1 via TCP/IP

B用户信息:
    mysql> status;
    --------------
    Connection id:        3
    Current database:    db1
    Current user:        root@localhost
    Connection:            Localhost via UNIX socket

C用户信息:
    mysql> status;
    --------------
    Connection id:        6
    Current database:    db1
    Current user:        root@localhost
    Connection:            Localhost via UNIX socket
      
D用户信息:
    mysql> status;
    --------------
    Connection id:        9
    Current database:    db1
    Current user:        root@localhost
    Connection:            127.0.0.1 via TCP/IP

2、4个用户分别开启事务,对db1里面的t1表进行DML
    start transaction;

A用户执行:
    mysql> select * from t1;
    +------+-------+
    | id   | name  |
    +------+-------+
    |    4 | mvk   |
    |    6 | marry |
    |    5 | fang  |
    |    5 | fang  |
    +------+-------+
    4 rows in set (0.00 sec)

mysql> insert into t1 values(1,'juhua'),(2,'long');
    Query OK, 2 rows affected (0.00 sec)
    Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from t1;
    +------+-------+
    | id   | name  |
    +------+-------+
    |    4 | mvk   |
    |    6 | marry |
    |    5 | fang  |
    |    5 | fang  |
    |    1 | juhua |
    |    2 | long  |
    +------+-------+
    6 rows in set (0.01 sec)

B用户执行:
    mysql> select * from t1;
    +------+-------+
    | id   | name  |
    +------+-------+
    |    4 | mvk   |
    |    6 | marry |
    |    5 | fang  |
    |    5 | fang  |
    +------+-------+
    4 rows in set (0.00 sec)

mysql>
    mysql> update t1 set name='liu' where id=5;
    等待50秒,报错
    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
在第5个会话层面查看:
    mysql> select * from information_schema.innodb_lock_waits;
    +-------------------+-------------------+-----------------+------------------+
    | requesting_trx_id | requested_lock_id | blocking_trx_id | blocking_lock_id |
    +-------------------+-------------------+-----------------+------------------+
    | 426545            | 426545:45:3:10    | 426540          | 426540:45:3:10   |
    +-------------------+-------------------+-----------------+------------------+
    1 row in set, 1 warning (0.00 sec)
    锁等待是426545,因为426540占着事务没有提交造成的

mysql> select * from information_schema.innodb_locks;
    +----------------+-------------+-----------+-----------+------------+-----------------+------------+-----------+----------+----------------+
    | lock_id        | lock_trx_id | lock_mode | lock_type | lock_table | lock_index      | lock_space | lock_page | lock_rec | lock_data      |
    +----------------+-------------+-----------+-----------+------------+-----------------+------------+-----------+----------+----------------+
    | 426545:45:3:10 | 426545      | X         | RECORD    | `db1`.`t1` | GEN_CLUST_INDEX |         45 |         3 |       10 | 0x000000242504 |
    | 426540:45:3:10 | 426540      | X         | RECORD    | `db1`.`t1` | GEN_CLUST_INDEX |         45 |         3 |       10 | 0x000000242504 |
    +----------------+-------------+-----------+-----------+------------+-----------------+------------+-----------+----------+----------------+
    
    mysql> select * from information_schema.innodb_trx\G
    *************************** 1. row ***************************
                        trx_id: 426546
                     trx_state: RUNNING
                   trx_started: 2019-08-07 17:24:36
         trx_requested_lock_id: NULL
              trx_wait_started: NULL
                    trx_weight: 1
           trx_mysql_thread_id: 6
                     trx_query: NULL
           trx_operation_state: NULL
             trx_tables_in_use: 0
             trx_tables_locked: 1
              trx_lock_structs: 1
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 1
             trx_rows_modified: 0
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    *************************** 2. row ***************************
                        trx_id: 426545
                     trx_state: LOCK WAIT
                   trx_started: 2019-08-07 17:21:36
         trx_requested_lock_id: 426545:45:3:10
              trx_wait_started: 2019-08-07 17:26:38
                    trx_weight: 5
           trx_mysql_thread_id: 3
                     trx_query: update t1 set name='liu' where id=5
           trx_operation_state: fetching rows
             trx_tables_in_use: 1
             trx_tables_locked: 1
              trx_lock_structs: 3
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 6
             trx_rows_modified: 2
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    *************************** 3. row ***************************
                        trx_id: 426540
                     trx_state: RUNNING
                   trx_started: 2019-08-07 17:20:10
         trx_requested_lock_id: NULL
              trx_wait_started: NULL
                    trx_weight: 4
           trx_mysql_thread_id: 8
                     trx_query: NULL
           trx_operation_state: NULL
             trx_tables_in_use: 0
             trx_tables_locked: 1
              trx_lock_structs: 2
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 1
             trx_rows_modified: 2
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    3 rows in set (0.00 sec)
    找到trx_mysql_thread_id对应的id号,show processlist看是否对应,然后commit事务即可。

改变情况:
    分别在B、C、D执行DML
    B:
    mysql> update t1 set name='liu' where id=5;
    C:
    mysql> delete from t1 where id=4;
    D:
    mysql> update t1 set id=8 where id=6;
    全部发生所等待
    
    mysql> select * from information_schema.innodb_lock_waits;
    +-------------------+-------------------+-----------------+------------------+
    | requesting_trx_id | requested_lock_id | blocking_trx_id | blocking_lock_id |
    +-------------------+-------------------+-----------------+------------------+
    | 426547            | 426547:45:3:4     | 426545          | 426545:45:3:4    |
    | 426546            | 426546:45:3:4     | 426547          | 426547:45:3:4    |
    | 426546            | 426546:45:3:4     | 426545          | 426545:45:3:4    |
    | 426545            | 426545:45:3:10    | 426540          | 426540:45:3:10   |
    +-------------------+-------------------+-----------------+------------------+
    
    mysql> select * from information_schema.innodb_trx\G
    *************************** 1. row ***************************
                        trx_id: 426547
                     trx_state: LOCK WAIT
                   trx_started: 2019-08-07 17:35:19
         trx_requested_lock_id: 426547:45:3:4
              trx_wait_started: 2019-08-07 17:36:48
                    trx_weight: 4
           trx_mysql_thread_id: 9
                     trx_query: update t1 set id=8 where id=6
           trx_operation_state: starting index read
             trx_tables_in_use: 1
             trx_tables_locked: 1
              trx_lock_structs: 2
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 1
             trx_rows_modified: 2
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    *************************** 2. row ***************************
                        trx_id: 426546
                     trx_state: LOCK WAIT
                   trx_started: 2019-08-07 17:24:36
         trx_requested_lock_id: 426546:45:3:4
              trx_wait_started: 2019-08-07 17:36:52
                    trx_weight: 2
           trx_mysql_thread_id: 6
                     trx_query: delete from t1 where id=4
           trx_operation_state: starting index read
             trx_tables_in_use: 1
             trx_tables_locked: 1
              trx_lock_structs: 2
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 2
             trx_rows_modified: 0
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    *************************** 3. row ***************************
                        trx_id: 426545
                     trx_state: LOCK WAIT
                   trx_started: 2019-08-07 17:21:36
         trx_requested_lock_id: 426545:45:3:10
              trx_wait_started: 2019-08-07 17:36:56
                    trx_weight: 5
           trx_mysql_thread_id: 3
                     trx_query: update t1 set name='liu' where id=5
           trx_operation_state: fetching rows
             trx_tables_in_use: 1
             trx_tables_locked: 1
              trx_lock_structs: 3
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 7
             trx_rows_modified: 2
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    *************************** 4. row ***************************
                        trx_id: 426540
                     trx_state: RUNNING
                   trx_started: 2019-08-07 17:20:10
         trx_requested_lock_id: NULL
              trx_wait_started: NULL
                    trx_weight: 4
           trx_mysql_thread_id: 8
                     trx_query: NULL
           trx_operation_state: NULL
             trx_tables_in_use: 0
             trx_tables_locked: 1
              trx_lock_structs: 2
         trx_lock_memory_bytes: 1136
               trx_rows_locked: 1
             trx_rows_modified: 2
       trx_concurrency_tickets: 0
           trx_isolation_level: REPEATABLE READ
             trx_unique_checks: 1
        trx_foreign_key_checks: 1
    trx_last_foreign_key_error: NULL
     trx_adaptive_hash_latched: 0
     trx_adaptive_hash_timeout: 0
              trx_is_read_only: 0
    trx_autocommit_non_locking: 0
    4 rows in set (0.00 sec)
    直接在426540对应的trx_mysql_thread_id: 8会话提交之后,发现B和D锁等待消失,只有C还有锁等待。
    查找innodb_lock_waits表看到426545还引起了锁等待。同理commit即可。
   
    mysql> select * from information_schema.innodb_lock_waits;
    +-------------------+-------------------+-----------------+------------------+
    | requesting_trx_id | requested_lock_id | blocking_trx_id | blocking_lock_id |
    +-------------------+-------------------+-----------------+------------------+
    | 426546            | 426546:45:3:4     | 426545          | 426545:45:3:4    |
    +-------------------+-------------------+-----------------+------------------+
    1 row in set, 1 warning (0.00 sec)

Lock wait timeout分析的更多相关文章

  1. SQL性能优化常见措施(Lock wait timeout exceeded)

    SQL性能优化常见措施 目 录 1.mysql中explain命令使用 2.mysql中mysqldumpslow的使用 3.mysql中修改my.ini配置文件记录日志 4.mysql中如何加索引 ...

  2. mysql死锁,等待资源,事务锁,Lock wait timeout exceeded; try restarting transaction解决

    前面已经了解了InnoDB关于在出现锁等待的时候,会根据参数innodb_lock_wait_timeout的配置,判断是否需要进行timeout的操作,本文档介绍在出现锁等待时候的查看及分析处理: ...

  3. java.sql.SQLException: Lock wait timeout exceeded --转

    org.springframework.dao.CannotAcquireLockException 的解决> 直接上 bug 的详细信息: 2012-03-12 15:20:31 XmlBea ...

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

    OMG写的时候崩溃了一次. 触发关注这个问题的事情是 我们在使用pt-online-schedule 改表的时候总是拿不到锁,并且报出mysql innodb Lock wait timeout ex ...

  5. com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction

    本文为博主原创: 以下为在程序运行过程中报的错误, org.springframework.dao.CannotAcquireLockException: ### Error updating dat ...

  6. mysql Lock wait timeout exceeded; try restarting transaction解决

    前面已经了解了InnoDB关于在出现锁等待的时候,会根据参数innodb_lock_wait_timeout的配置,判断是否需要进行timeout的操作,本文档介绍在出现锁等待时候的查看及分析处理: ...

  7. Spring_错误 java.sql.SQLException: Lock wait timeout exceeded | CannotAcquireLockException 的解决

    java.sql.SQLException: Lock wait timeout exceeded |  org.springframework.dao.CannotAcquireLockExcept ...

  8. ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction 表被锁的解决办法

    转自:https://blog.csdn.net/mchdba/article/details/38313881 前言:朋友咨询我说执行简单的update语句失效,症状如下:mysql> upd ...

  9. Lock wait timeout exceeded数据库死锁问题

    环境 MySQL5.5 现象 A.数据更新或新增后数据经常自动回滚. B.表操作总报 Lock wait timeout exceeded 并长时间无反应 解决方法 A.应急方法:show proce ...

随机推荐

  1. 不借助其他任何软件防止QQ被盗的小技巧

    分享一个小技巧(防止QQ被盗号): 在登录的时候前面加个0,点击登录,如果显示账号不存在,是因为你没有在添加或注册账号这儿登录,也就是切换账号.PC端也可以,如下图:                 ...

  2. java 多个数 组合成不同的组

    public static Stack<Integer> stack = new Stack<Integer>(); private static List<String ...

  3. lambda表达式笔记

    前几天一位好友分享了一篇文章,其中讲到了lambda表达式,正好最近看了一些内容,就做做笔记吧... lambda表达式服务于函数式接口,如果需要一个函数式接口的对象时,就可以用lambda表达式代替 ...

  4. Ubuntu 中linux 编译错误的(-)

    1.错误 compress.c:14:58: fatal error: zlib.h: No such file or directorycompilation terminated. 解决:sudo ...

  5. AttributeError: 'sys.flags' object has no attribute 'utf8_mode'

    AttributeError: 'sys.flags' object has no attribute 'utf8_mode' pycharm工程的py版本是3.6,结果即使使用py3.7编译后的py ...

  6. Android--ScrollView边界回弹效果

    /* * Copyright (C) 2006 The Android Open Source Project * * Licensed under the Apache License, Versi ...

  7. quartz2.3.0(五)制定错过执行任务的misfire策略,用pause,resume模拟job暂停执行和继续执行

    感谢兄台: <quartz-misfire 错失.补偿执行> misfire定义 misfire:被错过的执行任务策略 misfire重现——CronTrigger job任务类: pac ...

  8. Ubuntu 18.04下安装Steam顶级在线游戏平台

    Ubuntu 18.04下安装Steam顶级在线游戏平台 原创: 聆听世界的鱼 Linux公社 今天 Steam是由Valve公司开发的顶级在线游戏平台,是目前全球最大的综合性数字发行平台之一.它让你 ...

  9. 系统开启UAC情形下开机自启动程序如何以管理员权限启动

    系统开启UAC情形下开机自启动程序如何以管理员权限启动 题记:本文阐述的是在Windows系统开启UAC的情况下,开机自启动程序需要以管理员权限启动, 系统弹出UAC对话框,用户同意的情形下启动程序 ...

  10. ITIL《信息技术基础架构库》

    一 概述 1. ITIL 自上世纪70年代开始,个人计算机以及计算机网络开始在欧美发达国家普及.随着时间的推移,信息系统的规模越来越大,人们对信息系统的依赖也越来越强.特别是到了80年代,互联网开始普 ...