位置: 编程技术 - 正文

InnoDB数据库死锁问题处理(mysql innodb锁)

编辑:rootadmin

推荐整理分享InnoDB数据库死锁问题处理(mysql innodb锁),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:数据库死锁处理方法,mysql innodb锁,mysql innodb死锁,mysql innodb锁,数据库中死锁产生的原因和解决死锁的方法,mysql innodb锁,数据库死锁语句,mysql innodb锁,内容如对您有帮助,希望把文章链接给更多的朋友!

场景描述

在update表的时候出现DeadlockLoserDataAccessException异常 (Deadlock found when trying to get lock; try restarting transaction...)。

问题分析

这个异常并不会影响用户使用,因为数据库遇到死锁会自动回滚并重试。用户的感觉就是操作稍有卡顿。但是监控老是报异常,所以需要解决一下。

解决方法

在应用程序中update的地方使用try-catch。

我自己封装了一个函数,如下。

我用的是mybatis,所以只需将mapper传进函数,如果不用mybatis,需要自己创建并关闭数据库连接。

延伸:数据库死锁

数据库死锁是事务性数据库 (如SQL Server, MySql等)经常遇到的问题。除非数据库死锁问题频繁出现导致用户无法操作,一般情况下数据库死锁问题不严重。在应用程序中进行try-catch就可以。那么数据死锁是如何产生的呢?

InnoDB数据库死锁问题处理(mysql innodb锁)

InnoDB实现的是行锁 (row level lock),分为共享锁 (S) 和 互斥锁 (X)。

共享锁用于事务read一行。互斥锁用于事务update或delete一行。当客户A持有共享锁S,并请求互斥锁X;同时客户B持有互斥锁X,并请求共享锁S。以上情况,会发生数据库死锁。如果还不够清楚,请看下面的例子。

数据库死锁例子

首先,客户A创建一个表T,并向T中插入一条数据,客户A开始一个select事务,所以拿着共享锁S。

然后,客户B开始一个新事务,新事务是delete表T中的唯一一条数据。

删除操作需要互斥锁 (X),但是互斥锁X和共享锁S是不能相容的。所以删除事务被放到锁请求队列中,客户B阻塞。

最后,客户A也想删除表T中的那条数据:

死锁产生了!因为客户A需要锁X来删除行,而客户B拿着锁X并正在等待客户A释放锁S。看看客户A,B的状态:

客户A: 拿着锁S,等待着客户B释放锁X。客户B: 拿着锁X,等待着客户A释放锁S。

发生死锁后,InnoDB会为对一个客户产生错误信息并释放锁。返回给客户的信息:

ERROR (): Deadlock found when trying to get lock;try restarting transaction所以,另一个客户可以正常执行任务。死锁结束。

MYSQL5.7.9开启慢查询日志的技巧 用MYSQL5.7.9作为ZABBIX2.4.7的监控数据库.前段时间开启了慢查询日志,后来发现慢查询日志膨胀到了M查看最后条大部分都是0.1秒的后来想改,以前是动态

MySQL命令行界面中出现字符错误提示的原因及解决方法 ERROR(HY):Can'tinitializecharactersetgb搞了好半天,MySQL都重装了两次,号悲剧。。。之前设置了系统编码全都是UTF-8了的vi/etc/sysconfig/inLANG=zh_CN.UTF-8LANG

简述MySQL分片中快速数据迁移 推荐阅读:MySQL数据库跨操作系统的最快迁移方法mysql备份与迁移数据同步方法操作实践背景:travelrecord表定义为个分片,尝试将个分片中的2个分片

标签: mysql innodb锁

本文链接地址:https://www.jiuchutong.com/biancheng/319765.html 转载请保留说明!

上一篇:Mysql数据库分库和分表方式(常用)(Mysql数据库分库分表语句)

下一篇:MYSQL5.7.9开启慢查询日志的技巧(mysql 速度慢)

  • 个人所得税全年一次性奖金优惠政策
  • 销售无形资产增值税纳税义务发生时间
  • 取得的高速公路发票可以抵扣吗
  • 三栏式明细账适用于银行存款吗
  • 投资款要不要交企业所得税
  • 金税盘可以用安卓的线吗
  • 农民工工资专户管理暂行办法
  • 利润表中的其他综合收益
  • 境外机构可以开通b股账户
  • 计提存货减值准备怎么算
  • 本年利润包含增值税吗
  • 出纳人员怎么核酸检测
  • 机票电子行程单和发票的区别
  • 股权稀释需要交税吗
  • 苗木发票抵扣公式
  • 购进机器进项税额怎么核算?
  • 季度开票超过9万个人所得税
  • 企业自查补税报告怎么写?
  • 所得税汇算有研发费用可以不享受加计扣除吗
  • 小规模纳税人月销售额不超过10万免征
  • 个人所得税减半征收
  • 增值税发票不见了可以重开吗
  • 工程款的材料商可以直接起诉业主吗
  • 税务局开的专票可以抵扣吗
  • linux常用的命令大全
  • 怎么用苹果6splus
  • 股票退市后股票怎么处理
  • 酒店没有营业执照开业犯法吗
  • 双系统启动界面
  • 承租人对经营租赁和融资租赁会计处理方式
  • 评估价值时点依据什么
  • 新车车祸报废
  • PHP:pg_set_error_verbosity()的用法_PostgreSQL函数
  • 企业所得税的征税范围是什么
  • php中require和include是用来做什么的
  • thinkphp3.2.3
  • php时间戳转换成时间
  • php自定义变量的方法是
  • 租赁费用增值税率
  • openeuler基于
  • 用人单位招用失业人员补贴
  • 增资扩股税务处罚标准
  • ps怎么移动某个图案
  • c语言realloc函数的用法
  • python中Plotly Express是什么?
  • 房屋租赁时需要交税吗
  • 有留抵税额可以注销吗
  • 血液制品增值税税率
  • 增值税要计入应收账款吗
  • 发票报销哪些要素不能少
  • 跆拳道馆薪酬详细方案
  • 现金流量表的内部结构怎么算
  • 定期定额征收和核定征收的哪种税率高
  • 现金短缺与溢余解析
  • 资本公积金转增股本是利好吿
  • 车辆上牌的费用应付多少?
  • 物业公司管理费用都有哪些科目
  • 营改增对企业税负影响
  • 抵扣联和发票联的区别
  • 审计测试会计分录怎么做
  • 企业营运能力分析
  • 折现率的选择主要是根据什么来判断
  • mysql 最新稳定版本
  • sqlserver msdb
  • mysql5.7主从配置
  • centos页面
  • linux 网站备份
  • linux 系统查看
  • ubuntu配置vsftpd
  • win8.1应用商店无法连接网络
  • linux就要这样学
  • css div内容自动换行
  • jquery用什么编写
  • 基于js实现微信直播
  • pythonstl
  • jquery设置div的宽度和高度
  • 支付境外服务费代扣代缴增值税 会计凭证
  • 个人限购
  • 铁岭医保网上怎么交费
  • 上海买新房办贷款流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设