• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 分享一个MySQL死锁问题解决的方法

分享一个MySQL死锁问题解决的方法

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL死锁等相关知识,希望本文的分享对您有所帮助

分享一个MySQL死锁问题解决的方法

一、环境

  • CentOS, MySQL 5.6.21-70, JPA

  • 问题场景:系统有定时批量更新数据状态操作,每次更新上千条记录,表中总记录数约为500W左右。

二、错误日志

2017-2-25 17:38:41 org.hibernate.util.JDBCExceptionReporter logExceptions
严重: Lock wait timeout exceeded; try restarting transaction
2017-2-25 17:39:05 org.hibernate.util.JDBCExceptionReporter logExceptions
警告: SQL Error: 1213, SQLState: 40001
2017-2-25 17:39:05 org.hibernate.util.JDBCExceptionReporter logExceptions
严重: Deadlock found when trying to get lock; try restarting transaction

三、排查

Check InnoDB status for locks
mysql> SHOW ENGINE InnoDB STATUS;

Check MySQL open tables
mysql> SHOW OPEN TABLES WHERE In_use > 0;

Check pending InnoDB transactions
mysql> SELECT * FROM `information_schema`.`innodb_trx` ORDER BY `trx_started`; 

Check lock dependency - what blocks what
mysql> SELECT * FROM `information_schema`.`innodb_locks`;

排查后发现都是执行类似这样的语句出现问题的:


update t_task_tel set state='iok', update_date='2017-02-27 11:03:02' where tel_id=66042 and task_id=350199;


四、分析

搜索相关资料后发现,原来MySQL InnoDB并不一定都是行级锁。

相关参考资料片段如下:

锁选择
1)、如果更新条件没有走索引,例如执行”update from t1 set v2=0 where v2=5;” ,此时会进行全表扫描,扫表的时候,要阻止其他任何的更新操作,所以上升为表锁。
2)、如果更新条件为索引字段,但是并非唯一索引(包括主键索引),例如执行“update from t1 set v2=0 where v1=9;”

那么此时更新会使用Next-Key Lock。使用Next-Key Lock的原因:
a)、首先要保证在符合条件的记录上加上排他锁,会锁定当前非唯一索引和对应的主键索引的值;
b)、还要保证锁定的区间不能插入新的数据。
3)、如果更新条件为唯一索引,则使用Record Lock(记录锁)。

InnoDB根据唯一索引,找到相应记录,将主键索引值和唯一索引值加上记录锁。但不使用Gap Lock(间隙锁)。
由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例) ,否则MySQL将会执行Table Lock (将整个资料表单给锁住)。

根据分析结论,猜测是在更新_task_tel表时Where条件中tel_id和task_id没有建立UNIQUE(唯一索引)原因;

五、解决

据此分析,尝试通过tel_id和task_id两个字段建立UNIQUE(唯一索引)来解决。 (也可以先查询出来,然后根据主键ID来更新,这样不会因表中数据量较大影响线上业务)。

通过此种方式解决后,问题没有再重现。

如果你的问题和我遇到的类似,可以尝试据此解决。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-11分享MYSQL插入数据时忽略重复数据的方法
  • 2018-12-05MySQL入门教程1 —— 连接与断开服务器
  • 2018-12-05MySQL EXPLAIN 命令详解学习
  • 2018-12-05SQL货币数字转英文字符语句
  • 2018-12-05SQLServer触发器创建、删除、修改、查看示例代码
  • 2017-05-11mysql5.0版本下载地址集合
  • 2017-05-11MySQL ERROR 2013 (HY000)错误解决方法
  • 2018-12-05MySQL审计插件的测试(mcafee和mariadb版本)详情介绍
  • 2018-12-05mysql 备份与迁移 数据同步方法
  • 2018-12-05oracle创建存储过程两种方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Oracle AS关键字 提示错误
    • mysql创建数据表时指定默认值教程
    • MySQL 数据库 source 命令详解_MsSql
    • MySQL学习笔记3:表的基本操作介绍
    • mysql 协议的ColumnDefinition包及解析代码详情
    • Oracle 数据库中创建合理的数据库索引
    • MySQL 存储过程中执行动态 SQL 语句
    • SQLServer Top语句参数化方法
    • sqlserver2005 安装图解教程以及SQL 2005 SP3补丁安装图文教程
    • mysql布尔文本搜索教程

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有