Redisson分布式锁 原理&源码 分析

# 基于setnx实现的分布式锁存在的问题:

# 为了解决上面的问题,可以用Redisson

# Redisson入门

# Redisson可重入锁原理

获取锁的Lua脚本:

释放锁的Lua脚本:

# 锁重试原理分析

tryLock()底层代码分析

time :剩余的等待重试时间 ttl:现被持有的锁的剩余有效时间

计算尝试获取锁所消耗的时间,然后再计算出等待获取锁的剩余时间time,

如果time<=0,则不再重试了直接返回获取锁失败,

如果time>0,则通过subscribe去订阅别人释放锁的通知信号,如果在剩余的等待重试时间time里还没有等到通知信号,则取消订阅;

如果在剩余的等待重试时间里订阅到释放锁的信号了,就再重新计算一次剩余的等待重试时间time,如果time>0,则进入while(true)循环中尝试获得锁。

释放锁的lua脚本中的发布消息通知

# 看门狗更新锁有效时间 源码分析

# 释放锁源码

# 总结

相关推荐
泽02023 小时前
Linux之环境变量
java·linux·redis
济南java开发,求内推3 小时前
Redis一个服务器部署多个节点
服务器·数据库·redis
Full Stack Developme3 小时前
Python Redis 教程
开发语言·redis·python
夜泉_ly5 小时前
Redis -持久化
数据库·redis·缓存
用户31187945592186 小时前
redis-4.0.11-1.ky10.sw_64.rpm安装教程(申威麒麟V10 64位系统详细步骤)
redis
zym大哥大9 小时前
Redis-Zest
数据库·redis·缓存
zl97989910 小时前
Redis-stream、bitfield类型
数据库·redis·缓存
心随雨下10 小时前
Redis中Geospatial 实际应用指南
数据库·redis·分布式·缓存
月临水12 小时前
Redis 学习笔记(二)
redis·笔记·学习
Dreams_l12 小时前
初识redis(分布式系统, redis的特性, 基本命令)
数据库·redis·缓存