一、核心前置:生产分布式锁四大刚性底线
所有Redis分布式锁,必须同时达标,缺一不可上线:全局强互斥、宕机自动防死锁、禁止跨线程误删锁、集群切换高可用不丢锁。纯手写简易锁,线上必触发故障。
二、原生Redis手写锁:极简迭代+致命短板速览
2.1 初代 SETNX 裸写版(全线禁用)
核心逻辑:无过期时间加锁,业务结束直接删锁。致命隐患:服务宕机锁永久残留,直接引发全局死锁阻塞业务,无任何应急兜底能力。
2.2 二代 SETNX+EX 原子版(治标留大坑)
优化点:用NX EX原子命令加过期时间,解决永久死锁。遗留高危问题:业务卡顿超时锁提前释放,后续线程抢锁后,旧线程收尾无脑误删有效锁,击穿并发安全。
2.3 三代终版:唯一标识+Lua释锁(手写最优上限)
核心优化:锁埋入线程专属UUID,Lua脚本原子校验归属后删锁,规避误删、兜底防死锁。硬性短板:无自动续期、不支持可重入、主从异步复制易丢锁,仅适配低并发非核心边缘业务,交易链路严禁使用。
三、Redisson高阶锁:生产极简落地+核心硬核能力
3.1 碾压手写锁四大核心优势
内置看门狗后台自动续期,杜绝业务超时锁失效;Hash结构天然可重入,适配多层嵌套业务;全场景Lua脚本封装,全程原子无并发漏洞;兼容全Redis架构,配齐可重入、公平、读写、红锁全高阶形态。
3.2 极简集成+核心可直接投产代码
仅引入Redisson官方启停依赖,复用SpringBoot Redis原生配置即可自动装配。核心实操:获取可重入锁,无阻塞快速抢锁,业务后置线程归属判断安全释锁,极简无冗余编码,适配90%线上核心场景。
高阶适配:秒杀用公平锁排队防插队;商品读多用读写锁提吞吐;资金对账核心链路部署红锁,规避主从切换锁丢失风险。
四、线上真实死锁极简复盘+当场止血+长效根治
故障现场:批量定时任务触发锁滞留,全链路线程阻塞、订单接口雪崩、消息大量堆积。根因定位:老旧业务沿用初代手写锁,服务灰度下线未执行释锁,无过期兜底,锁key永久常驻Redis。
应急止血:运维批量清理滞留锁key,临时限流拦截无效流量,关停叠加批量定时任务,快速恢复业务链路。
长效优化:全站下线所有手写分布式锁,统一归口Redisson;核心交易链路强制开启看门狗续期;高危资金链路加固红锁架构;新增锁滞留、锁长持监控告警;上线代码卡点拦截不合规锁代码。
五、生产极简选型速判清单(直接归档用)
低并发后台任务:标配Redisson可重入锁,禁用手写锁,默认看门狗兜底;秒杀高并发排队:选用公平锁,搭配限时快速降级;读多写少商品场景:适配读写锁,兼顾安全与高吞吐;资金对账核心链路:三节点红锁兜底,强一致性防锁丢失。