当前位置: 移动技术网 > IT编程>开发语言>Java > Java编程redisson实现分布式锁代码示例

Java编程redisson实现分布式锁代码示例

2019年07月19日  | 移动技术网IT编程  | 我要评论

最近由于工作很忙,很长时间没有更新博客了,今天为大家带来一篇有关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与分布式系统简析以及本站其他相关专题,希望对大家有所帮助。如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网