写点什么

【高并发】你知道吗?大家都在使用 Redisson 实现分布式锁了!!

作者:冰河
  • 2022 年 6 月 01 日
  • 本文字数:3240 字

    阅读完需:约 11 分钟

【高并发】你知道吗?大家都在使用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();
复制代码

写在最后

如果觉得文章对你有点帮助,请微信搜索并关注「 冰河技术 」微信公众号,跟冰河学习高并发编程技术。


最后,附上并发编程需要掌握的核心技能知识图,祝大家在学习并发编程时,少走弯路。



好了,今天就到这儿吧,我是冰河,我们下期见~~

发布于: 18 小时前阅读数: 19
用户头像

冰河

关注

公众号:冰河技术 2020.05.29 加入

互联网资深技术专家,《深入理解分布式事务:原理与实战》,《海量数据处理与大数据技术实战》和《MySQL技术大全:开发、优化与运维实战》作者,mykit-data与mykit-transaction-message框架作者。【冰河技术】作者。

评论

发布
暂无评论
【高并发】你知道吗?大家都在使用Redisson实现分布式锁了!!_并发编程_冰河_InfoQ写作社区