Redis

关注公众号 jb51net

关闭
首页 > 数据库 > Redis > Redisson分布式锁看门狗

深入解析Redisson分布式锁看门狗机制

作者:一个搬砖的农民工

本文主要介绍了深入解析Redisson分布式锁看门狗机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、Redisson分布式锁概述 🚀

☘️ 1.1 分布式锁的意义

在分布式系统中,多个节点可能同时访问共享资源,导致数据不一致或竞态条件。分布式锁通过协调不同节点对共享资源的访问,确保数据的一致性和并发访问的安全性。

☘️ 1.2 Redisson分布式锁的优势

二、Redisson分布式锁的原理 🚀

🌳 2.1 锁的实现方式

Redisson分布式锁主要基于Redis的SETNX(Set if Not Exists)命令和DEL(Delete)命令实现。SETNX命令尝试设置一个值,如果该键不存在,则设置成功并返回1;否则返回0DEL命令则用于删除一个键。

🌳 2.2 看门狗机制

🌳 2.3 锁的自动续期机制

🌳 2.4 锁的释放

当一个线程完成临界区的操作后,应当手动释放锁。在Redisson中,这通常通过调用unlock()方法来完成。如果线程没有手动释放锁,而是异常结束或被其他方式中断,Redis的键空间通知功能可以确保锁在一段时间后自动释放。

三、Redisson 看门狗机制 🚀

🍁 3.1 参数说明

🍁 3.2 举例几个常见的方法

	RLock lock = redissonClient.getLock("lockKey001");

	// 没设置leaseTime,有看门狗机制
	lock.tryLock();
	// 实际调用的RedissonLock的tryLock(long waitTime, TimeUnit unit) 
	// 没设置leaseTime,有看门狗机制
	lock.tryLock(3, TimeUnit.SECONDS); 
	// 实际调用的RedissonLock的lock(long leaseTime, TimeUnit unit)方法
	// 设置了leaseTime,没有看门狗机制
	lock.lock(10, TimeUnit.SECONDS);
	// 设置了leaseTime=10s,没有看门狗机制
	lock.tryLock(3,10, TimeUnit.SECONDS);

🍁 3.3 tryLock()

tryLock() 方法默认会有看门狗机制,因为没有设置过期时间,默认是30s过期,但是看门狗每10s续期一次,每次续期都重新设置过期时间为30s。如果没有释放锁,理论上会无限续期。

🍁 3.4 tryLock(long waitTime, TimeUnit unit)

// 源码
 public boolean tryLock(long waitTime, TimeUnit unit) throws InterruptedException {
        return this.tryLock(waitTime, -1L, unit);
    }

因为这个方法没有设置 leaseTime,因此默认也是有看门狗机制的。默认是30s过期,但是看门狗每10s续期一次,每次续期都重新设置过期时间为30s。如果没有释放锁,理论上会无限续期。

🍁 3.5 lock(long leaseTime, TimeUnit unit)

设置了 leaseTime 不会有看门狗机制

 // 源码
 public void lock(long leaseTime, TimeUnit unit) {
        try {
            this.lockInterruptibly(leaseTime, unit);
        } catch (InterruptedException var5) {
            Thread.currentThread().interrupt();
        }
    }

🍁 3.6 tryLock(long waitTime, long leaseTime, TimeUnit unit)

设置了 leaseTime 不会有看门狗机制

// 源码
public boolean tryLock(long waitTime, long leaseTime, TimeUnit unit) throws InterruptedException {
	long time = unit.toMillis(waitTime);
	long current = System.currentTimeMillis();
	...........
}

四、其他 🚀

🍄 4.1 看门狗生命周期

当一个没有设置leaseTime 的锁一创建 Redisson 就会生成一个对应的看门狗,如果执行了unlock()则看门狗会一起销毁。不然会直到java进程终止(重启、销毁)才会消失。

🍄 4.2 看门狗是Redisson 生成的吗

是的,看门狗机制是Redisson 后台启的一个定时任务,不是Redis自带的。

到此这篇关于深入解析Redisson分布式锁看门狗机制的文章就介绍到这了,更多相关Redisson分布式锁看门狗内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文