Redis教程

Redisson实现分布式锁

本文主要是介绍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以后自动删除,就解决了在高并发场景下的一些问题。

这篇关于Redisson实现分布式锁的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!