redisson锁笔记

本文详细介绍了Redisson分布式锁的工作原理,通过分析源码揭示了其获取和释放锁的过程。在获取锁时,Redisson使用了Lua脚本避免竞态条件,并支持可重入特性。解锁过程同样遵循特定逻辑。此外,针对Redis Cluster,Redisson有一套心跳检测机制,确保锁的有效性。
摘要由CSDN通过智能技术生成

redisson version:2.1.4

去查看源码的原因:

以前简单理解的基于redis的锁,就是去setnx一个key,然后设置一个过期时间。多线程的时候,谁能set成功,说明谁获取锁成功。

然后解锁操作就是删除之前的key或者等待过期。

现在用了下redisson的锁,开始也以为是这样的,认为其他线程也能强制解锁。结果测试发现不行。

源码:

获取锁

 

<span style="font-size:14px;">private Long tryLockInner(final long leaseTime, final TimeUnit unit) {
        internalLockLeaseTime = unit.toMillis(leaseTime);

        return commandExecutor.evalWrite(getName(), RedisCommands.EVAL_INTEGER,
		//step1
                "local v = redis.call('get', KEYS[1]); " +
                                "if (v == false) then " +
				//step2
                                "  redis.call('set', KEYS[1], cjson.encode({['o'] = ARGV[1], ['c'] = 1}), 'px', ARGV[2]); 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值