写点什么

Redisson:这么强大的实现分布式锁框架,你还没有?

  • 2021 年 12 月 20 日
  • 本文字数:3020 字

    阅读完需:约 10 分钟

摘要:Redisson 框架十分强大,基于 Redisson 框架可以实现几乎你能想到的所有类型的分布式锁。

 

本文分享自华为云社区《【高并发】你知道吗?大家都在使用Redisson实现分布式锁了!!》,作者:冰 河 。

 

Redisson 框架是基于 Redis 实现的分布式锁,非常强大,只需要拿来使用就可以。

Redisson 框架十分强大,基于 Redisson 框架可以实现几乎你能想到的所有类型的分布式锁。这里,我就列举几个类型的分布式锁,并各自给出一个示例程序来加深大家的理解。

1.可重入锁(Reentrant Lock)


Redisson 的分布式可重入锁 RLock Java 对象实现了 java.util.concurrent.locks.Lock 接口,同时还支持自动过期解锁。


public void testReentrantLock(RedissonClient redisson){	RLock lock = redisson.getLock("anyLock");	try{		// 1. 最常见的使用方法		//lock.lock();		// 2. 支持过期解锁功能,10秒钟以后自动解锁, 无需调用unlock方法手动解锁		//lock.lock(10, TimeUnit.SECONDS);		// 3. 尝试加锁,最多等待3秒,上锁以后10秒自动解锁		boolean res = lock.tryLock(3, 10, TimeUnit.SECONDS);		if(res){ //成功		// do your business		}	} catch (InterruptedException e) {		e.printStackTrace();	} finally {		lock.unlock();	}}
复制代码


​Redisson 同时还为分布式锁提供了异步执行的相关方法:


public void testAsyncReentrantLock(RedissonClient redisson){	RLock lock = redisson.getLock("anyLock");	try{		lock.lockAsync();		lock.lockAsync(10, TimeUnit.SECONDS);		Future<Boolean> res = lock.tryLockAsync(3, 10, TimeUnit.SECONDS);		if(res.get()){		// do your business		}	} catch (InterruptedException e) {		e.printStackTrace();	} catch (ExecutionException e) {		e.printStackTrace();	} finally {		lock.unlock();	}}
复制代码


2.公平锁(Fair Lock)


Redisson 分布式可重入公平锁也是实现了 java.util.concurrent.locks.Lock 接口的一种 RLock 对象。在提供了自动过期解锁功能的同时,保证了当多个 Redisson 客户端线程同时请求加锁时,优先分配给先发出请求的线程。


public void testFairLock(RedissonClient redisson){	RLock fairLock = redisson.getFairLock("anyLock");	try{		// 最常见的使用方法		fairLock.lock();		// 支持过期解锁功能, 10秒钟以后自动解锁,无需调用unlock方法手动解锁		fairLock.lock(10, TimeUnit.SECONDS);		// 尝试加锁,最多等待100秒,上锁以后10秒自动解锁		boolean res = fairLock.tryLock(100, 10, TimeUnit.SECONDS);	} catch (InterruptedException e) {		e.printStackTrace();	} finally {		fairLock.unlock();	}}
复制代码


​Redisson 同时还为分布式可重入公平锁提供了异步执行的相关方法:


RLock fairLock = redisson.getFairLock("anyLock");fairLock.lockAsync();fairLock.lockAsync(10, TimeUnit.SECONDS);Future<Boolean> res = fairLock.tryLockAsync(100, 10, TimeUnit.SECONDS);
复制代码


3.联锁(MultiLock)


Redisson 的 RedissonMultiLock 对象可以将多个 RLock 对象关联为一个联锁,每个 RLock 对象实例可以来自于不同的 Redisson 实例。


public void testMultiLock(RedissonClient redisson1,RedissonClient redisson2, RedissonClient redisson3){	RLock lock1 = redisson1.getLock("lock1");	RLock lock2 = redisson2.getLock("lock2");	RLock lock3 = redisson3.getLock("lock3");	RedissonMultiLock lock = new RedissonMultiLock(lock1, lock2, lock3);	try {		// 同时加锁:lock1 lock2 lock3, 所有的锁都上锁成功才算成功。		lock.lock();		// 尝试加锁,最多等待100秒,上锁以后10秒自动解锁		boolean res = lock.tryLock(100, 10, TimeUnit.SECONDS);	} catch (InterruptedException e) {		e.printStackTrace();	} finally {		lock.unlock();	}}
复制代码


4.红锁(RedLock)


Redisson 的 RedissonRedLock 对象实现了 Redlock 介绍的加锁算法。该对象也可以用来将多个 RLock 对象关联为一个红锁,每个 RLock 对象实例可以来自于不同的 Redisson 实例。


public void testRedLock(RedissonClient redisson1,RedissonClient redisson2, RedissonClient redisson3){	RLock lock1 = redisson1.getLock("lock1");	RLock lock2 = redisson2.getLock("lock2");	RLock lock3 = redisson3.getLock("lock3");	RedissonRedLock lock = new RedissonRedLock(lock1, lock2, lock3);	try {		// 同时加锁:lock1 lock2 lock3, 红锁在大部分节点上加锁成功就算成功。		lock.lock();		// 尝试加锁,最多等待100秒,上锁以后10秒自动解锁		boolean res = lock.tryLock(100, 10, TimeUnit.SECONDS);	} catch (InterruptedException e) {		e.printStackTrace();	} finally {		lock.unlock();	}}
复制代码


5.读写锁(ReadWriteLock)


Redisson 的分布式可重入读写锁 RReadWriteLock,Java 对象实现了 java.util.concurrent.locks.ReadWriteLock 接口。同时还支持自动过期解锁。该对象允许同时有多个读取锁,但是最多只能有一个写入锁。


RReadWriteLock rwlock = redisson.getLock("anyRWLock");// 最常见的使用方法rwlock.readLock().lock();// 或rwlock.writeLock().lock();// 支持过期解锁功能// 10秒钟以后自动解锁// 无需调用unlock方法手动解锁rwlock.readLock().lock(10, TimeUnit.SECONDS);// 或rwlock.writeLock().lock(10, TimeUnit.SECONDS);// 尝试加锁,最多等待100秒,上锁以后10秒自动解锁boolean res = rwlock.readLock().tryLock(100, 10, TimeUnit.SECONDS);// 或boolean res = rwlock.writeLock().tryLock(100, 10, TimeUnit.SECONDS);...lock.unlock();
复制代码


6.信号量(Semaphore)


Redisson 的分布式信号量(Semaphore)Java 对象 RSemaphore 采用了与 java.util.concurrent.Semaphore 相似的接口和用法。


RSemaphore semaphore = redisson.getSemaphore("semaphore");semaphore.acquire();//或semaphore.acquireAsync();semaphore.acquire(23);semaphore.tryAcquire();//或semaphore.tryAcquireAsync();semaphore.tryAcquire(23, TimeUnit.SECONDS);//或semaphore.tryAcquireAsync(23, TimeUnit.SECONDS);semaphore.release(10);semaphore.release();//或semaphore.releaseAsync();
复制代码


7.可过期性信号量(PermitExpirableSemaphore)


Redisson 的可过期性信号量(PermitExpirableSemaphore)实在 RSemaphore 对象的基础上,为每个信号增加了一个过期时间。每个信号可以通过独立的 ID 来辨识,释放时只能通过提交这个 ID 才能释放。


RPermitExpirableSemaphore semaphore = redisson.getPermitExpirableSemaphore("mySemaphore");String permitId = semaphore.acquire();// 获取一个信号,有效期只有2秒钟。String permitId = semaphore.acquire(2, TimeUnit.SECONDS);// ...semaphore.release(permitId);
复制代码


8.闭锁(CountDownLatch)


Redisson 的分布式闭锁(CountDownLatch)Java 对象 RCountDownLatch 采用了与 java.util.concurrent.CountDownLatch 相似的接口和用法。


RCountDownLatch latch = redisson.getCountDownLatch("anyCountDownLatch");latch.trySetCount(1);latch.await();// 在其他线程或其他JVM里RCountDownLatch latch = redisson.getCountDownLatch("anyCountDownLatch");latch.countDown();
复制代码


点击关注,第一时间了解华为云新鲜技术~

发布于: 1 小时前阅读数: 4
用户头像

提供全面深入的云计算技术干货 2020.07.14 加入

华为云开发者社区,提供全面深入的云计算前景分析、丰富的技术干货、程序样例,分享华为云前沿资讯动态,方便开发者快速成长与发展,欢迎提问、互动,多方位了解云计算! 传送门:https://bbs.huaweicloud.com/

评论

发布
暂无评论
Redisson:这么强大的实现分布式锁框架,你还没有?