Redisson lua脚本解读

该博客详细介绍了Redisson分布式锁的实现方式,包括其数据结构、加锁和解锁的Lua脚本,以及看门狗续期机制。Redisson使用Redis作为底层存储,通过key-value形式的hash数据结构来管理锁,确保了锁的重入性和自动释放功能。在加锁失败时,客户端会循环尝试获取锁,确保了锁的公平性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Redisson锁的redis数据结构

lock_name作为key,

value为hash,hash最多只会有一条数据hash的key为uuid+:+threadId,value为重入次数

uuid:每个RedissonClient里面连接管理中的id=uuid,创建时初始化

加锁lua脚本(copy from version 3.13.6)

KEYS[1] 锁的名字

ARGV[1] 锁自动失效时间(毫秒,默认30s(看门狗续期时长))

ARGV[2] hash子项的key(uuid+threadId)

--如果锁不存在
if (redis.call('exists', KEYS[1]) == 0) then
--重入次数初始为0后加一
redis.call('hincrby', KEYS[1], ARGV[2], 1);
--设锁的过期时间
redis.call('pexpire', KEYS[1], ARGV[1]);
--返回null-代表加锁成功
return nil;
--if结束符
end;
--如果加锁的进程已存在
if (redis.call('hexists', KEYS[1], ARGV[2]) == 1) then
--重入次数加一
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值