如何减少死锁发生_mysql并发场景优化
发布时间 - 2026-01-23 00:00:00 点击率:次减少 MySQL 死锁需降低资源争抢强度与时长:缩短事务执行时间、按主键升序访问多行、优化索引与隔离级别、加强监控及热点分段更新。
减少 MySQL 死锁,核心在于降低事务对资源的争抢强度和时长,而不是完全避免——死锁在高并发下无法彻底消除,但可大幅降低发生概率。
缩短事务执行时间
长事务会持有锁更久,增加与其他事务交叉等待的概率。应尽量让事务“快进快出”:
- 避免在事务内做耗时操作(如 HTTP 调用、复杂计算、大文件读写)
- 提前准备好所有数据,减少事务中 SQL 的数量
- 批量更新尽量用单条 INSERT ... ON DUPLICATE KEY UPDATE 或 REPLACE INTO 替代多条语句
- 查询尽量加覆盖索引,避免事务中触发回表或临时表
按固定顺序访问资源
死锁常因两个事务以相反顺序更新同一组行(如事务 A 先改 id=1 再改 id=5,事务 B 反过来)。统一访问顺序可切断循环等待链:
- 更新多行时,始终按主键升序(或唯一索引字段)排序后再执行,例如:
UPDATE t SET status=1 WHERE id IN (5,1,3) → 改为 WHERE id IN (1,3,5) - 业务层批量操作前先对 ID 列排序,再拼接 SQL 或使用 ORDER BY 子句
- 避免混合使用不同索引路径访问同一张表(如一个事务走 name 索引,另一个走 age 索引更新重叠行)
合理设计索引与隔离级别
不合适的索引会导致锁范围扩大;过高的隔离级别会加剧锁竞争:
- 确保 WHERE 条件能命中最左前缀的高效索引,避免全表扫描导致锁住过多无关行
- 少用 SELECT ... FOR UPDATE,优先考虑应用层校验 + 唯一约束 + 普通 UPDATE,失败后重试
- 非强一致性场景可将隔离级别从 REPEATABLE READ 降为 READ COMMITTED(InnoDB 下后者不启用间隙锁,显著减少锁冲突)
- 确认业务是否真需要可重复读,很多支付/订单类场景其实只需读已提交
监控与主动规避
靠日志和指标提前发现隐患,比等线上报错更有效:
- 开启 innodb_print_all_deadlocks = ON,把死锁信息输出到 error log,定期分析高频冲突表和 SQL 模式
- 监控 Innodb_row_lock_waits 和 Innodb_row_lock_time_avg,数值突增说明锁竞争加剧
- 对热点行(如账户余额、库存计数器)采用“分段更新”策略(如把 total_stock 拆成
stock_shard_0 ~ stock_shard_9),分散锁竞争
- 关键更新接口加入轻量重试逻辑(如捕获 Deadlock found when trying to get lock 后延迟 10–100ms 重试 1–2 次)
# mysql
# ai
# 热点
# 有锁
# sql
# for
# select
# Error
# 循环
# 接口
# 并发
# http
# 死锁
# 升序
# 重试
# 执行时间
# 时长
# 主键
# 子句
# 只需
# 线上
# 可将
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
香港服务器选型指南:免备案配置与高效建站方案解析
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Laravel如何使用Blade组件和插槽?(Component代码示例)
Laravel如何配置和使用缓存?(Redis代码示例)
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
Linux系统命令中screen命令详解
制作电商网页,电商供应链怎么做?
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
高防服务器如何保障网站安全无虞?
教你用AI润色文章,让你的文字表达更专业
微信小程序 require机制详解及实例代码
如何用好域名打造高点击率的自主建站?
如何在宝塔面板中修改默认建站目录?
Python制作简易注册登录系统
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
千库网官网入口推荐 千库网设计创意平台入口
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
如何快速选择适合个人网站的云服务器配置?
米侠浏览器网页背景异常怎么办 米侠显示修复
如何注册花生壳免费域名并搭建个人网站?
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
青岛网站建设如何选择本地服务器?
详解jQuery中基本的动画方法
Python文件异常处理策略_健壮性说明【指导】
google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
Laravel如何创建自定义中间件?(Middleware代码示例)
成都网站制作公司哪家好,四川省职工服务网是做什么用?
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
晋江文学城电脑版官网 晋江文学城网页版直接进入
Laravel如何使用Gate和Policy进行授权?(权限控制)
canvas 画布在主流浏览器中的尺寸限制详细介绍
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
JavaScript如何实现音频处理_Web Audio API如何工作?
如何正确下载安装西数主机建站助手?
使用Dockerfile构建java web环境
制作公司内部网站有哪些,内网如何建网站?
Laravel如何实现API资源集合?(Resource Collection教程)
如何在橙子建站上传落地页?操作指南详解
香港服务器如何优化才能显著提升网站加载速度?
Laravel如何使用Passport实现OAuth2?(完整配置步骤)


