MySQL行锁的优劣剖析:怎样降低行锁对性能的阻碍?

《MySQL行锁的利弊剖析:如何降低行锁对性能的消极影响》

行锁是针对数据表中行记录实施的锁定机制,由引擎层的相关引擎予以实现。

从两阶段锁说起

在InnoDB的事务场景下,行锁并非在需要时立即获取后就马上释放,而是要等到事务结束才会释放,此即为两阶段锁协议

明确这一设定后,若事务需锁定多个行,需将最易引发锁冲突、最可能影响并发程度的锁尽量后置

举个例子,存在电影票交易业务,顾客A要在影院B购买电影票,涉及如下操作:

  • 从顾客A的账户余额中扣减电影票的费用;

  • 向影院B的账户余额中增加电影票的费用;

  • 记录一条交易的日志。

这三个操作对应三条语句,为保证原子性,会将其置于同一个事务中。观察可知,语句2最易产生冲突,因为不同顾客买票时都会通过语句2修改同一行数据。

依据两阶段锁协议,锁等待难以避免,而将语句2安排在最后,例如按312的顺序执行,就能让最易引发锁冲突的锁处于后面位置,最大程度减少事务间的等待情况。

死锁与死锁检测

当并发系统中不同线程出现循环的资源依赖情形,相关线程都在等待其他线程释放资源时,会致使这些线程陷入无限等待状态,此状况被称为死锁。

以行锁为例:

MySQL行锁的优劣剖析:怎样降低行锁对性能的阻碍?

此时,事务A等待事务B释放id=2的行锁,事务B等待事务A释放id=1的行锁,从而造成死锁。

出现死锁时,有两种应对策略:

  • 直接进入等待状态,直至超时。该超时时间可通过参数innodb_lock_wait_timeout进行设置。在InnoDB中,默认值为50秒,这通常难以接受。但也不能将该时间设置得过小,否则无法区分死锁与简单锁等待情况,易造成误判。所以,此方法一般不被采用。

  • 发起死锁检测,发现死锁后,主动回滚死锁链条中的某一事务,使其他事务能够继续执行。设置参数innode_deadlock_detect=on,表示开启该逻辑。

正常情况下采用第二种策略,但死锁检测也有一定负担。若n个事务都要更新同一行,由于每个新被阻塞的线程都需判断自身是否引发死锁,其复杂度为O(n),总复杂度会达到O(n²)

针对这种热点行更新导致的性能问题,主要思路如下:

  • 对于相同行的更新操作,在进入引擎前进行排队。如此,InnoDB内部就不会有大量死锁检测工作。

  • 将一行数据拆分为逻辑上的多行以减少锁冲突。比如将影院账户拆成10个记录,每次增加金额时随机选取其中一条记录进行操作,每次冲突概率变为原来的1/10,可减少锁等待次数,进而降低死锁检测的CPU消耗。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/13063.html

(0)
LomuLomu
上一篇 2025 年 8 月 5 日
下一篇 2025 年 8 月 5 日

相关推荐

  • 新版 Cursor 把其他 AI 编程工具按在地上摩擦了!

    大家好,我是汤师爷~ AI编程助手Cursor背后的Anysphere公司刚刚完成了1亿美元的B轮融资,估值直接飙升至26亿美元。 四个月前,这家公司刚拿下6000万美元,估值还只有4亿美元。如今,增长6.5倍,这速度,简直让人怀疑开挂了。 Anysphere不仅融资拿到手软,收入增长更是逆天。 公司从4月的年收入400万美元,短短六个月后,10月的月收入竟…

    2025 年 1 月 12 日
    91300
  • 促销系统:促销活动、优惠券、优惠规则概念模型设计

    大家好,我是汤师爷~ 概念模型设计是促销系统开发的关键环节,我们需要基于之前的功能分析,将复杂的促销业务拆解成清晰的领域概念,这些概念之间的关系界定和边界划分,将直接决定系统的可维护性和扩展性。 促销系统核心概念模型 通过对促销业务的分析,我们可以抽象出促销系统的关键概念模型。 1、促销活动模型 促销活动模型对活动的各个要素和规则进行抽象,包含活动名称、描述…

    2025 年 1 月 6 日
    61000
  • 全新体验版官方最新版webstorm激活码,专业破解教程

    申明:本教程 WebStorm破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 WebStorm 2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的WebStorm。 如果觉得…

    2025 年 10 月 22 日
    22000
  • 2025年最新PyCharm激活码分享 | 永久破解PyCharm至2099年教程

    本方法适用于JetBrains全家桶,包括PyCharm、IDEA、DataGrip、Goland等所有产品! 先给大家看看最新版PyCharm成功激活的截图,有效期直达2099年,完全免费使用! 下面我将用详细的图文教程,手把手教你如何永久激活PyCharm到2099年。 这个方法不仅适用于最新版本,也兼容所有旧版PyCharm! Windows/Mac/…

    PyCharm激活码 2025 年 8 月 29 日
    21400
  • 最全clion激活码白嫖渠道与小白专用clion破解教程

    重要提示:本文涉及的CLion破解补丁与激活码资源均源自网络收集,仅限个人学习研究使用,严禁用于任何商业用途。建议有条件的用户支持正版软件! 话不多说,先上图证明实力——CLion 2025.2.1版本已成功激活至2099年,效果相当给力! 下面将通过详细的图文步骤,手把手教你搞定最新版CLion的激活流程。 前期准备 特别提醒:若您曾尝试其他破解方案未果,…

    2026 年 1 月 8 日
    16400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信