当前位置: 首页 > news >正文

Redis中的红锁

红锁(RedLock) 是 Redis 官方提出的一种 分布式锁算法,用于解决在 Redis 集群或多主节点环境下分布式锁的一致性与高可用问题。它是由 Redis 作者 Antirez(Salvatore Sanfilippo) 在 2016 年提出的,主要应用于 高可用分布式环境中的互斥锁设计


🧠 背景:为什么需要红锁

在单个 Redis 实例中加锁比较简单,可以用 SET resource_name my_random_value NX PX 3000 实现一个互斥锁。但是在 分布式环境 中,例如有多个 Redis 实例组成集群,或者使用哨兵部署了多个主节点,就不能保证锁的一致性。

比如:

  • 某个 Redis 节点宕机或网络分区(网络延迟),可能导致锁失效或“多客户端同时持有锁”。

这时就需要引入红锁算法来解决这个问题。


🔐 红锁的核心思想(RedLock 原理)

假设有 N 个独立的 Redis 节点(通常为 5 个),RedLock 的核心流程如下:

✅ 加锁流程:
  1. 客户端生成唯一 ID(UUID) 作为锁的值,用于标识谁持有锁。
  2. 并发地N 个 Redis 实例 请求加锁,使用 SET key value NX PX 3000 设置过期时间。
  3. 只要获取到了超过一半(例如 N=5 时为 3 个)实例的锁,就认为加锁成功。
  4. 加锁过程必须在一个时间窗口内完成(比如锁的过期时间的 2/3 时间),以避免因网络延迟导致的锁失效。
🔓 解锁流程:
  1. 只解锁那些 value 与客户端 ID 相同 的锁,防止误删别人的锁。
  2. 遍历所有节点发送 DEL 操作。

✅ 加锁成功条件

  • 至少在 N/2 + 1 个 Redis 节点 上成功加锁。
  • 加锁总耗时 < 所设定锁的有效期(考虑网络延迟等)。

📌 红锁设计的好处

优点说明
高可用多个 Redis 节点容忍部分节点宕机或网络抖动
安全性高加锁需要超过一半 Redis 节点达成共识
可靠性强每个节点的锁都有自动过期,防止死锁

⚠️ 注意事项与争议

  • Antirez 本人提出红锁,但社区存在争议,例如 Martin Kleppmann 质疑其一致性保障。
  • 在实际应用中,如果 Redis 部署本身具备高可用特性(如使用哨兵 + 主从 + 自动故障转移),单实例锁配合业务逻辑 + watchdog 往往也能满足需求。
  • 红锁实现复杂,不适合所有场景。

🔧 实际开发中建议

场景是否用红锁
高并发、强一致性、多个 Redis 节点✅ 建议使用红锁或成熟组件如 Redisson 的 RedLock
单节点或 Redis 哨兵模式,高可用部署❌ 可使用普通的 Redis 分布式锁即可
多语言/多端系统分布式协同锁✅ 建议用红锁或依赖数据库乐观锁

🛠️ Redisson 对红锁的实现

Redisson 是一个 Java 的 Redis 客户端,内置对红锁的支持:

RLock lock = redisson.getMultiLock(lock1, lock2, lock3);
lock.lock();
try {// 执行业务逻辑
} finally {lock.unlock();
}


文章转载自:
http://analogously.wkuuf.cn
http://antsy.wkuuf.cn
http://breathalyser.wkuuf.cn
http://arid.wkuuf.cn
http://abettor.wkuuf.cn
http://basaltiform.wkuuf.cn
http://anthroposophy.wkuuf.cn
http://calciphylaxis.wkuuf.cn
http://bioclimatic.wkuuf.cn
http://aqueduct.wkuuf.cn
http://bastille.wkuuf.cn
http://chandigarh.wkuuf.cn
http://bravura.wkuuf.cn
http://bulbaceous.wkuuf.cn
http://anatine.wkuuf.cn
http://amblyoscope.wkuuf.cn
http://amniotin.wkuuf.cn
http://beanball.wkuuf.cn
http://agana.wkuuf.cn
http://canonry.wkuuf.cn
http://bequest.wkuuf.cn
http://armhole.wkuuf.cn
http://abbreviate.wkuuf.cn
http://ascorbate.wkuuf.cn
http://antithesis.wkuuf.cn
http://calumny.wkuuf.cn
http://badminton.wkuuf.cn
http://anamorphosis.wkuuf.cn
http://catamaran.wkuuf.cn
http://altocumulus.wkuuf.cn
http://www.dtcms.com/a/281300.html

相关文章:

  • ADC采集、缓存
  • Axios 完整功能介绍和完整示例演示
  • 映美打印机-URL页面打印
  • Spring MVC 执行流程详解:一次请求经历了什么?
  • 微信小程序:在ios中border边框显示不全
  • XCTF-repeater三链破盾:PIE泄露+ROP桥接+Shellcode执行的艺术
  • PyTorch 数据加载实战:从 CSV 到图像的全流程解析
  • 股指期货主连和次主连的区别是什么?
  • 游戏加速器核心技术:动态超发
  • Linux 文件系统实现层详解:原理、结构与驱动衔接
  • 人类气道黏膜下腺类器官:解析呼吸炎症与感染的新平台
  • Sharding-JDBC 分布式事务实战指南:XA/Seata 方案解析(三)
  • (3)从零开发 Chrome 插件:网页图片的批量下载
  • Google EMM是什么?
  • Git Idea 冲突解决
  • GitHub Pages无法访问以点号.开头的目录
  • 【实时Linux实战系列】实时数据流的网络传输
  • 百度移动开发面经合集
  • 【matlab】三维路面谱生成代码
  • Altium Designer 25 安装与配置完整教程
  • 【高并发服务器】多路复用的总结 eventfd timerfd
  • 2.3 数组与字符串
  • Flutter 股票图实现分析与解决方案
  • 深入理解高性能字节池 bytebufferpool
  • 1.easypan-登录注册
  • AbMole小课堂 | Angiotensin II(血管紧张素Ⅱ)在心血管研究中的多元应用
  • 基于51单片机和16X16点阵屏、矩阵按键的小游戏《俄罗斯方块》
  • 清理C盘--办法
  • python的形成性考核管理系统
  • 学习笔记(37):构建一个房价预测模型,并通过可视化全面评估模型效果