mysql innodb引擎下的行锁由于意外没有被释放,导致后面的请求无法继续,怎么办?

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/80108576 在一个@Transactional注解的方法中进行调试,但莫名其妙的就报了下面这个错误:从内容上看不出个所以然,大概的猜测是事务开启了,一直没有commit,导致MySQL的行被锁住了。
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/80108576

在一个@Transactional注解的方法中进行调试,但莫名其妙的就报了下面这个错误:

这里写图片描述

从内容上看不出个所以然,大概的猜测是事务开启了,一直没有commit,导致MySQL的行被锁住了。下面这个错误证实了我的想法,再次更新同一条数据时,依然失败。

这里写图片描述

那么,该怎么解决掉这个问题呢?

网上找资料呗。

有几篇文章值得深入的学习和思考:

  1. mysql的锁–行锁,表锁,乐观锁,悲观锁,https://www.cnblogs.com/deliver/p/5730616.html
  2. DRUID连接池的实用 配置详解,https://www.cnblogs.com/wuyun-blog/p/5679073.html
  3. mysql innodb引擎下的行锁获得后 由于意外没有被释放,导致后面的请求无法获得该行锁,怎么办?(由于CSDN的Markdown有些小问题,为了显示得更舒服一点,网址在第四点)
  4. https://www.zhihu.com/question/56380924/answer/149316845

首先,我的数据库链接使用的是阿里的Druid,所以第二篇文章中读到以下关键信息:

testOnBorrow |true| 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。

而我项目中的该值设置为false。瞬间感觉问题就要马上解决了,但不了解事情的真相就想要解决问题,是不可能的。果然,把数据库链接配置中testOnBorrow 设置为true,于事无补。

那么,第三篇文章对我应该是有帮助的。毕竟我先要把锁释放掉,因为我还有一大顿的测试要做。从第三篇文章中我找到以下关键信息:

其次,如果真的出现了这样的问题,那就通过命令show engine innodb status\G,找到ACTIVE时间长的(需要通过其中信息确定一下是不是这个事务,最好别找错了),通过这些信息找到对应的thread id,然后kill connection threadid,将其杀掉,恢复业务正常运行,然后再去改业务代码上存在的问题吧。

这位朋友提供的方法我认为是正解,于是使用Navicat进入数据库的命令行界面,执行:
show engine innodb status\G
结果令人失望:

mysql> show engine innodb status\G;
1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘\G’ at line 1
mysql>

该怎么办呢?

网上找资料呗。

有朋友提供这样的信息,说这条语句只能在mysql的cmd或者shell界面下执行,我很怀疑这句话的正确性。但事实证明我是多么的无知,他说的是对的,我的怀疑是多余的。

这里写图片描述

为什么?为什么真理永远被别人掌握?为什么我就偏偏不知道呢?

对于技术能力在我之上的,能解决我问题的人,我感到由衷的佩服,请收下我的膝盖。

嗯,不过,等一等,这条语句show engine innodb status\G;执行后的结果都什么玩意啊?我表示看不懂,难道不看了吗?

当然不行,要解决问题啊,耐着头皮继续看呗。

这里写图片描述

嗯,发现了“金银岛”,这不就是“ACTIVE时间长的”?懂行的人的话语永远都那么少,那么精辟,那么直达人心。其中thread id为“221489”,还等什么,立马kill掉它。

mysql> kill connection  221489;
Query OK, 0 rows affected (0.00 sec)

mysql>

我就好像是出门大张的小兵,出门之前元帅告诉我要这么这么这么这么做,嗯,我点点头,表示对他的话一知半解。到底对不对?有待检验。

[SQL]UPDATE mem_point SET `shop_offset` = 0 WHERE uid=35;
受影响的行: 1
时间: 0.000s

嗯,没错,老板说得千真万确,之前一直被锁的update,现在可以顺利执行了。
果然,有的时候,你要相信,当自己无知的时候,别人说的话永远都是真理。你需要做的就是,去检验它是否真的是真理。


我就是这一个人,永远都在进步。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
27天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
131 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
7天前
|
存储 关系型数据库 MySQL
MySQL引擎InnoDB和MyISAM的区别?
InnoDB是MySQL默认的事务型存储引擎,支持事务、行级锁、MVCC、在线热备份等特性,主索引为聚簇索引,适用于高并发、高可靠性的场景。MyISAM设计简单,支持压缩表、空间索引,但不支持事务和行级锁,适合读多写少、不要求事务的场景。
30 9
|
26天前
|
存储 安全 关系型数据库
InnoDB引擎特性
InnoDB事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定和外键。MySQL5.5.5之后,InnoDB作为默认存储引擎,InnoDB主要特性有: InnoDB给MySQL提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句中提供了一个类似Oracle的非锁定读。 InnoDB是为处理巨大数据量的最大性能设计。它的CPU效率可能是任何其他基于磁盘关系的数据库引擎所不能匹敌的。 InnoDB存储引擎完全与MySQL服务器整合,InnoDB存储引擎为在主内存中缓存数据和索引而维持它自己的缓冲池
|
27天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的表空间
InnoDB是MySQL默认的存储引擎,主要由存储结构、内存结构和线程结构组成。其存储结构分为逻辑和物理两部分,逻辑存储结构包括表空间、段、区和页。表空间是InnoDB逻辑结构的最高层,所有数据都存放在其中。默认情况下,InnoDB有一个共享表空间ibdata1,用于存放撤销信息、系统事务信息等。启用参数`innodb_file_per_table`后,每张表的数据可以单独存放在一个表空间内,但撤销信息等仍存放在共享表空间中。
|
27天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的段、区和页
MySQL的InnoDB存储引擎逻辑存储结构与Oracle相似,包括表空间、段、区和页。表空间由段和页组成,段包括数据段、索引段等。区是1MB的连续空间,页是16KB的最小物理存储单位。InnoDB是面向行的存储引擎,每个页最多可存放7992行记录。
|
27天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL的InnoDB存储引擎
InnoDB是MySQL的默认存储引擎,广泛应用于互联网公司。它支持事务、行级锁、外键和高效处理大量数据。InnoDB的主要特性包括解决不可重复读和幻读问题、高并发度、B+树索引等。其存储结构分为逻辑和物理两部分,内存结构类似Oracle的SGA和PGA,线程结构包括主线程、I/O线程和其他辅助线程。
【赵渝强老师】MySQL的InnoDB存储引擎
|
6天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
26天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
34 1
|
28天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
39 4
|
1月前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
192 1