深入理解分布式锁:从原理到实践

1. 为何要使用分布式锁

在分布式系统中,多个服务实例可能同时访问共享资源,传统的本地锁失效。分布式锁应运而生,解决以下关键问题:

  • 并发资源访问控制
  • 防止数据不一致
  • 避免重复操作
  • 保证业务原子性

典型场景:

  • 订单生成
  • 库存扣减
  • 秒杀系统
  • 分布式任务调度

2. 分布式锁的几种实现方式

2.1 数据库实现

-- 悲观锁
SELECT * FROM table WHERE id = ? FOR UPDATE

优点:简单直接
缺点:性能低,数据库压力大

2.2 ZooKeeper实现

// 创建临时顺序节点
create -e -s /lock path

优点:可靠性高
缺点:依赖ZooKeeper集群

2.3 Redis实现

--加锁
SET key value NX PX 30000

优点:性能高
缺点:需要自己实现续期机制

3. 为什么总选择Redis?

  • 性能优势
  • 内存操作,毫秒级响应
  • 原子操作命令
  • 支持集群和高可用
  • 实现简单

4. Redisson的优越性

既然是redis,那么开箱即用,便是大家所需,redission应运而生

  • 功能全面
  • 自动续期
  • 可重入锁
  • 公平锁
    代码示例
RLock lock = redissonClient.getLock("myLock");
lock.lock();
try {
    // 业务逻辑
} finally {
    lock.unlock();
}

5. Redisson看门狗失效及解决

redission虽然有看门狗续命机制,但也不能做到万无一失

5.1 失效场景

  • 有垃圾收集器( GC ),有时运行期间会暂停所有正在运行的线程。这些GC暂停甚至有时会持续数分钟 !即使像HotSpot JVM CMS所谓的“并发”垃圾收集器也不能完全与应用代码并行运行,需要时时地停止活动的线程。通过改变分配模式或调整GC某些参数可 减少暂停,但是我们还是要防范最差情况以提供可靠的保证。

  • 当操作系统执行线程上下文切换时,或者虚拟机管理程序切换到 个虚机时
    正在运行的线程可能会在代码的任意位置被暂停。在虚拟机环境中,这种被其
    虚拟机中断的 PU时间称为窃取时间 。如果机器负载很高( 等待运行的钱程很
    长),被暂停的线程可能需要 段时间之后才能再次运行。

  • 如果操作系统配置了基于磁盘的内存交换分区,内存访问可能触发缺页中断,进
    而需要从磁盘中加载内存页。 I/O 进行时(通常比较慢)线程为暂停。如果内存
    使用压力很大,还可能迫使更多的页面换出到磁盘 极端的情况下,操作系统可
    会花费大量时间在页面换入换出上,而实际工作完成很少(所谓的颠簸’)。为
    了避免 问题,通常在服务器上禁用分页,宁愿杀死一些进程来释放内 而不
    是反复抖动。
    总之,当节点1拿到锁在执行时,如果看门狗未来的及续命,被暂停了,而redis锁过期了,节点2就有可能拿到锁,然后节点1复活继续执行,就会造成并发问题

5.2解决方案

5.2.1 显式设置超时

// 增加锁的超时时间
RLock lock = redissonClient.getLock("your_lock");
lock.lock(60, TimeUnit.SECONDS);  // 显式设置较长超时

5.2.2 业务幂等设计

  • 唯一请求ID
  • 状态机
  • 补偿机制

5.2.3 JVM参数调优

调整JVM GC策略
优化Full GC频率和时间
使用G1或ZGC替代
增加锁的容错机制

# 调整内存大小
-Xms4g -Xmx4g  # 初始和最大堆内存一致
-XX:MaxMetaspaceSize=256m  # 限制元空间大小

# 垃圾回收器选择
-XX:+UseG1GC  # 推荐G1收集器
-XX:MaxGCPauseMillis=200  # 控制最大GC停顿时间

# 减少Full GC频率
-XX:+DisableExplicitGC  # 禁止显式调用System.gc()

结语
分布式锁是分布式系统中的利器,选择合适的方案和框架至关重要。Redisson提供了强大且易用的分布式锁解决方案,但仍需谨慎设计和使用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容