Redisson 分布式锁可重入的原理

目录

[1. 使用 Redis 实现分布式锁存在的问题](#1. 使用 Redis 实现分布式锁存在的问题)

[2. Redisson 的分布式锁解决不可重入问题的原理](#2. Redisson 的分布式锁解决不可重入问题的原理)


1. 使用 Redis 实现分布式锁存在的问题

  • 不可重入:同一个线程无法两次 / 多次获取锁
  • 举例
    • method1 执行需要获取锁
    • method2 执行也需要(同一把)锁
    • 如果 method1 中调用了 method2,就会出现死锁的情况
    • method1 执行的过程是同一个线程,但是锁无法识别,则无法重入

2. Redisson 的分布式锁解决不可重入问题的原理

  • 原理
    • 判断是否可重入:记录占有锁的当前线程和想要获取锁的线程是否是同一个线程,如果是则获取锁成功
    • 获取锁
      • 判断锁是否是自己的
      • 在 hash 的 value 中记录锁总共被(同一线程)获取的次数,获取一次,value + 1,且要重置锁的有效期,给重入的方法执行预留充足时间
    • 释放锁:判断锁的重入次数(即 value)是否为 0
      • 如果为 0,说明重入锁的层数到了最外层(method1),可以执行释放锁的逻辑
      • 如果 value > 0,说明还没有到最外层(还在执行 method2),则不能释放锁,而是将 value - 1,表示跳到外面一层,且需要重置锁的有效期
  • 核心思想:利用 Redis 中的 hash 结构,记录获取锁的线程和重入次数
  • 获取锁和释放锁的原子性:Lua 脚本
相关推荐
大飞哥~BigFei1 小时前
乐企数电发票分布式发票号码生成重复的问题修复思路分享
java·分布式·数电发票号码生成
活跃的煤矿打工人6 小时前
【星海出品】分布式存储数据库etcd
数据库·分布式·etcd
未来会更好yes6 小时前
Centos 7.6安装redis-6.2.6
linux·redis·centos
刘某的Cloud8 小时前
rabbitmq常用命令
linux·运维·分布式·rabbitmq·系统
熏鱼的小迷弟Liu8 小时前
【Redis】Redis Zset实现原理:跳表+哈希表的精妙设计
数据库·redis·散列表
观无11 小时前
Redis远程链接应用案例
数据库·redis·缓存·c#
慧一居士12 小时前
Zookeeper HA集群搭建
分布式·zookeeper
冼紫菜12 小时前
[特殊字符] 分布式定时任务调度实战:XXL-JOB工作原理与路由策略详解
分布式
好想有猫猫13 小时前
【Redis】服务端高并发分布式结构演进之路
数据库·c++·redis·分布式·缓存
孔令飞14 小时前
使用 Go 与 Redis Streams 构建可靠的事件驱动系统
redis·ai·云原生·golang·kubernetes