- 产生背景
服务器集群模式下需要对临界资源实现互斥访问 - 实现方案
- 基于数据库
使用唯一索引或排他锁来实现。
缺点是IO限制导致的性能较差,同时支持功能太少,需要额外开发锁超时、锁失效等功能。 - 基于KV缓存
一般通过redis来实现。
一种是单机方案,即通过单个redis实例,set key value ex/px timeout nx语句实现加锁,通过lua脚本比较key和value实现解锁,通过watchDog看门狗来实现业务运行时间超过“锁超时时间”时的续期,该方案问题在于单点故障问题;
另一种是哨兵模式方案, 通过引入主从架构和哨兵机制,提升了系统的鲁棒性,但仍然会有主从切换时分布式锁可能被同时获取、以及由于网络原因导致的“脑裂”(多个master节点)等问题;
第三种是RedLock方案,通过多个并列的redis实例提升系统的鲁棒性,加锁时需要对每个redis实例都加锁,只有超过一半的实例都加锁成功才算加锁成功。这种方案极大恶化了性能,同时在一些边界情况如某个redis实例中的锁过期时客户端在GC导致仍然在使用锁等场景仍然有问题 - 基于一致性协议
一般通过zookeeper实现,主要借助临时有序节点和watcher机制,客户端在获取锁时,会在zookeeper中创建一个临时有序节点(先创建的节点序号更小,优先级更高),序号最小的节点能获取到锁,同时通过watcher机制观察节点状态,当客户端解锁时,对应的临时有序节点会在zookeeper中注销,watcher观察到节点注销后,会通知下一个序号最小的节点获取到锁。
zookeeper是鲁棒性最强的方案,但是在一些极边界情况下,仍然有问题,比如客户端网络异常会导致对应临时有序节点被注销,这样就会有新的客户端能拿到锁,可能就造成了锁被同时持有。
- 基于数据库
- 方案选型
- 对性能没要求,对分布式锁的功能需求也极简单,可以考虑数据库方案,但一般不建议。
- 对性能要求高,允许极端情况容错,可以采用Redis的方案。
- 对性能要求较高,同时对一致性要求相当严格,可以采用zookeeper的方案。
分布式锁简介
张小明
前端开发工程师
【无人艇编队】基于数据驱动神经预测器 分布式通信网络 制导向量场GVF5艘欠驱动自主水面船舶USV的分布式路径跟踪与编队控制Matlab仿真,确保多USV在复杂轨迹保持预设编队,更贴近实际水面航行场景
✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 🍊个人信条:格物致知,完整Matlab代码获取及仿…
重构 Flutter 网络层:从 Dio 裸奔到分层封装的企业级实践
欢迎大家加入[开源鸿蒙跨平台开发者社区](https://openharmonycrossplatform.csdn.net),一起共建开源鸿蒙跨平台生态。 在 Flutter 开发中,网络请求是连接前端与后端的 “命脉”。很多开发者初期会直接使用 Dio 裸写请求 —— 把 URL、参数、拦截器混在…
考虑可再生能源消纳的电热综合能源系统日前经济调度模型研究附Matlab代码
✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…
ComfyUI-Manager升级终极指南:一键解决配置迁移与节点兼容性问题
ComfyUI-Manager升级终极指南:一键解决配置迁移与节点兼容性问题 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager ComfyUI-Manager作为ComfyUI生态系统的核心管理工具,其版本升级直接影响着整个…
从海外硕士到AI产品经理,他的转型之路藏着一个关键选择
一、 一段“跨界”成功的启示近日,一位拥有韩国知名大学硕士学位的朱同学,成功斩获了令人心动的AI产品经理Offer。这份工作,无论在薪资待遇、团队氛围还是未来平台上,都完全符合甚至超出了他最初的预期。他的故事并非简单的“学霸…
华硕笔记本性能调优新选择:G-Helper实战经验分享
华硕笔记本性能调优新选择:G-Helper实战经验分享 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: ht…