- 产生背景
服务器集群模式下需要对临界资源实现互斥访问 - 实现方案
- 基于数据库
使用唯一索引或排他锁来实现。
缺点是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的方案。
分布式锁简介
张小明
前端开发工程师
为什么IDEA提示不推荐@Autowired❓️如果使用@Resource呢❓️
IDEA(IntelliJ IDEA)在字段上使用 Autowired 进行依赖注入时,会提示警告 “Field injection is not recommended”(字段注入不推荐)。这是因为 Spring 官方和 IDEA 的 Spring 插件都推荐优先使用构造函数注入ÿ…
理解 Cursor 的核心概念、优势和适用场景。
Cursor 的核心概念 Cursor 是一个AI 第一的代码编辑器(AI-first code editor),它基于 Visual Studio Code (VS Code) 的开源代码分叉开发,由 Anysphere 公司打造。它的核心理念是将 AI 深度集成到编程工作中,让开发者…
【血压估算】基于 AR 模型结合两种最小均方(LMS)方法,通过桡动脉血压信号估计主动脉血压信号附Matlab代码
✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 🍊个人信条:格物致知,完整Matlab代码获取及仿…
深蓝词库转换:三分钟搞定全平台输入法词库同步
深蓝词库转换:三分钟搞定全平台输入法词库同步 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 还在为换输入法时词库无法迁移而烦恼吗?深蓝词…
[iOS原理] Block的本质
[iOS原理] Block的本质 文章目录[iOS原理] Block的本质前置研究iOS内存五大分区栈区堆区全局区 / 静态区常量区代码区isa指针BlockBlock的本质Block的三种类型__block的本质ARC 在某些情况下会对 block 自动进行一次 copy 操作,将其从栈区移动到堆区Block的应用及其…
百度网盘下载提速终极指南:三步告别限速困扰
还在为百度网盘那令人困扰的下载速度而苦恼吗?当你的宽带明明可以全速运行,却因为网盘限速而只能以缓慢的速度下载文件时,这种体验确实让人沮丧。今天介绍的baidu-wangpan-parse工具,作为一款专业的百度网盘直链解析神器ÿ…