Java编程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();
总结
以上就是本文关于java编程redisson实现分布式锁代码示例的全部内容,感兴趣的朋友可以参阅:、、spring cloud与分布式系统简析以及本站其他相关专题,希望对大家有所帮助。如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!