问题原因:
       今天线上环境,突然出现一个问题,追踪原因是数据库中的一条语句报错,错误内容:
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解决方案的更多相关文章

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

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

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

    一.问题描述 在做查询语句时,MySQL 抛出了这样的异常:锁等待超时 Lock wait timeout exceeded; try restarting transaction,是当前事务在等待其 ...

  3. Caused by: java.sql.BatchUpdateException: Transaction error, need to rollback. errno:1205 Lock wait timeout exceeded; try restarting transaction

    更新的时候报 Caused by: java.sql.BatchUpdateException: Transaction error, need to rollback. errno:1205 Loc ...

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

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

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

    测试库一条update语句报错:ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction mysql> ...

  6. pymysql.err.InternalError: (1205, 'Lock wait timeout exceeded; try restarting transaction')错误处理

    问题描述: 在使用pymysql库时,利用游标执行插入操作,产生错误,会出现pymysql.err.InternalError: (1205, 'Lock wait timeout exceeded; ...

  7. ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction解决办法

    一.问题描述: 同事反馈线上一个表有其中一条数据无法删除,其他都正常,我拿到删数据的sql,尝试执行,报错如下: mysql> delete from facebook_posts where ...

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

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

  9. 【问题解决:死锁】Lock wait timeout exceeded; try restarting transaction的问题

    执行数据删除操作时一直超时并弹出Lock wait timeout exceeded; try restarting transaction错误 解决办法 1.先查看数据库的事务隔离级别 select ...

随机推荐

  1. one by one 项目 part 2

    在网上百度了一下mySQL常用语句 ,整理如下: 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3. ...

  2. 登陆sharepoint的主页,提示:文件存在(异常来自 HRESULT:0x80070050)

    用sharepoint搭建了Project2007的服务器之后,由于我们公司管理域的服务器崩溃了,必须重新再加一次域,而域和服务器是关联的,即使域的名字一样,但该名字所对应的ID是不一样的,会导致一些 ...

  3. IRanges package

    1)介绍 在分析序列时,我们通常对特定的连续子序列感兴趣. 例如,a矢量可以被认为是按字母顺序排列的小写字母序列. 我们将第一个五个字母(a到e)称为连续的子序列,而仅包含元音的子序列不会是连续的. ...

  4. Linux下tar.gz 安装

    将安装文件拷贝至你的目录中 如果是以root身份登录上的,就将软件拷贝至/root中. cp xxx.tar.gz /root 解压缩包 tar xvzf xxx.tar.gz 切换到安装目录下 cd ...

  5. 使用sizemask来确保索引不越界

    [使用sizemask来确保索引不越界] 在redis的字典实现中,有一个sizemask字段. 此字段的作用是当使用下标访问数据时,确保下标不越界. 如当前size为8时,sizemask为7(0x ...

  6. 对象导航查询和OID查询(补)

    ----------------siwuxie095                                 对象导航查询         以客户和联系人为例(一对多)     1.应用场景 ...

  7. jQuery中animate()对Firefox无效的解决办法

    在使用 animate()做返回顶部的动画时,会出现对Firefox无效的情况,如: $('body').animate({scrollTop:'0'},500); 它对Chrome,IE,Opera ...

  8. windows,phalcon工具的安装使用

    一.使用工具之前,必须安装phalcon的扩展,也就是php_phalcon.dll动态链接库 phalcon官方地址:https://github.com/phalcon/cphalcon/rele ...

  9. This page contains the following error

    解决办法:将header头注释掉 header("content-type:text/xml; charset=UTF-8");

  10. 抽象 abstract 和 接口 interface。 java 的 堆 和 栈。 参数传递(基本类型和普通对象的区别)

    package com.test; import com.test.Pro; //protected 修饰的成员只能在本包中和 继承该类的方法中使用 public abstract class Tes ...