标签:加锁 Thread 实现 lock 解锁 30s Redisson 分布式
自己手动实现分布式加锁
//1、获取一把锁,只要锁的名字一样,就是同一把锁
RLock lock = redisson.getLock("my-lock");
//2、加锁
lock.lock();//阻塞式等待
try{
System.out.println("加锁成功,执行业务。。。"+Thread.currentThread().getId());
Thread.sleep(3000);
}catch(Exception e){
}finally{
//3、解锁
System.out.println("释放锁。。。"+Thread.currentThread().getId());
lock.unlock();
}
可以看到Redisson加锁和我们之前手动加锁的操作一样,需要保证KEY值唯一
Redisson即使没有手动解锁,Redisson也会自动删锁,
1、Redisson解决了锁的自动续期,如果业务超长,运行期间会自动给锁续上新的30s,不用担心业务时间长,锁自动过期被删掉,默认加的锁都是30s。
2、加锁的业务只要运行完成,就不会给当前锁续期,即使不手动解锁,锁默认在30s以后自动删除,就解决了在高并发场景下的一些问题。
标签:加锁,Thread,实现,lock,解锁,30s,Redisson,分布式 来源: https://www.cnblogs.com/aluna/p/15754043.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。