spring-integration-redis中分布式锁RedisLockRegistry的使用
创始人
2024-05-30 19:57:34
0

pom依赖:

org.springframework.boot

spring-boot-starter-data-redis

org.springframework.integration

spring-integration-redis

配置:

@Configuration

public class RedisLockConfig {

@Bean

public RedisLockRegistry redisLockRegistry(RedisConnectionFactory redisConnectionFactory) {

//第一个参数redisConnectionFactory

//第二个参数registryKey,分布式锁前缀,设置为项目名称会好些

//该构造方法对应的分布式锁,默认有效期是60秒.可以自定义

return new RedisLockRegistry(redisConnectionFactory, "boot-launch");

//return new RedisLockRegistry(redisConnectionFactory, "boot-launch",60);

}

}

方式1:

Lock lock = redisLockRegistry.obtain("lockkey-" + 1);
//tryLock尝试获取锁(成功返回true,失败返回false);if (lock.tryLock()) {try {// 业务代码块} finally {//走到这里说明获取锁一定是成功的try{lock.unlock();}catch (IllegalStateException e){//业务操作时间过长,会导致锁超时内系统释放,这里就会产生超时异常log.error("释放时发现锁过期");}}} else {//走到这里说明获取锁一定是失败的的log.info("并发抢锁失败");}

方式2:

Lock lock = redisLockRegistry.obtain("lockkey-" + 1);
//lock()一直循环获取锁,循环周期为100毫秒(成功了则无返回,失败了则抛异常),理论上一定能获取到锁,因为会一直循环取锁try {lock.lock();// 业务代码块(这里要判断并发情况下的业务幂等性)}catch (CannotAcquireLockException e){//当redis挂掉时执行redis操作失败会产生异常CannotAcquireLockException;说明获取锁失败了log.error("get redis lock fail");} finally {//走到这里 获取锁不一定是成功的,异常时也走,因此需要判断lock状态if(Objects.noNull(lock)){//锁存在才需要释放try{lock.unlock();}catch (IllegalStateException e){//业务操作时间过长,会导致锁超时内系统释放,这里就会产生超时异常log.error("释放时发现锁过期");}}}

方式3:

Lock lock = redisLockRegistry.obtain("lockkey-" + 1);
try {
//tryLock(3, TimeUnit.SECONDS):在3秒钟内循环获取锁,超过3秒还没有获取到就认为获取失败了,这个方法会抛出异常InterruptedException,boolean isLocked = lock.tryLock(3, TimeUnit.SECONDS);if (isLocked) {// 业务代码块}} catch (InterruptedException e) {log.error("get redis lock fail");}finally {//获取锁失败的时候也会走,需要判断锁失败时不去释放if(Objects.noNull(lock)){//锁存在才需要释放try{lock.unlock();}catch (IllegalStateException e){//业务操作时间过长,会导致锁超时内系统释放,这里就会产生超时异常log.error("释放时发现锁过期");}}}

总结:

解决同一个用户并发操作同一个资源时,如提交时按钮连击、多端调用同一个业务接口:使用方式1;方式2(使用方式2时需要做幂等判断,如连击操作多次调用时,对第二次调用不做处理)

解决并发限流时,如抽奖系统中对商品sku库存做锁操作,防止多个用户同时扣减库存导致库存数量少扣:使用方式2、或者方式3(锁等待时间=预计业务代码执行时间)

三方式都要注意释放锁时做锁过期处理

相关内容

热门资讯

安卓系统怎么删除appstor... 手机里appstore里的应用越来越多,是不是感觉有点乱糟糟的?别急,今天就来教你怎么轻松删除安卓系...
安卓新系统新功能,解锁创新功能... 你知道吗?最近安卓系统又来了一次大升级,带来了好多新功能,简直让人眼前一亮!想象你的手机就像是一个魔...
手机安卓系统应用下载,解锁智能... 你有没有发现,现在的生活越来越离不开手机了?尤其是安卓系统的手机,功能强大,应用丰富,简直就是一个移...
快手苹果系统换安卓,快手助力苹... 最近有没有发现你的快手APP突然变得有点不一样?没错,就是那个我们每天刷刷刷,看看搞笑视频、直播带货...
安卓系统没有寻车铃,轻松找回爱... 你有没有遇到过这种情况?手机里安卓系统的寻车铃突然失灵了,找车的时候急得团团转,心里那个懊恼啊!别急...
安卓系统的网络定位,安卓系统网... 你有没有发现,现在不管走到哪里,手机都能精准地告诉你所在的位置?这就是安卓系统的网络定位功能,它就像...
安卓系统怎样改电话,安卓系统电... 手机用久了是不是觉得有点卡?或者想换个新系统体验一下?别急,今天就来手把手教你如何给安卓手机换系统,...
安卓系统有什么优势,引领智能时... 你有没有想过,为什么安卓系统这么受欢迎呢?它就像一个万能的魔法师,总能给你带来惊喜。今天,就让我带你...
怎么区分安卓系统平板,如何区分... 你有没有想过,身边那么多平板电脑,怎么才能一眼就认出哪个是安卓系统的呢?别急,今天就来给你揭秘,怎么...
安卓苹果选择哪个系统,助您明智... 你有没有想过,手机里的那个小小的操作系统,其实就像是我们生活中的小助手,每天陪伴着我们,帮我们处理各...
安卓系统怎么关gps定位系统,... 手机里的GPS定位系统有时候真是让人又爱又恨。有时候,我们想要保护自己的隐私,不想让别人知道我们在哪...
电脑安卓系统怎么引导,电脑上安... 你有没有想过,你的安卓系统电脑是怎么一步步引导你进入这个神奇的数字世界的呢?今天,就让我带你一探究竟...
ios系统和安卓系统打王者,系... 亲爱的手机控们,你是不是也和我一样,对手机游戏情有独钟?尤其是那款风靡全球的《王者荣耀》,无论是闲暇...
安卓系统无法手动输入,人工智能... 最近我发现了一个让人头疼的问题,那就是安卓系统竟然无法手动输入!这可真是让人摸不着头脑,毕竟我们平时...
安卓导航如何定制系统,安卓系统... 你有没有想过,你的安卓导航系统其实可以变得超级个性化呢?没错,就是那个每天陪你上下班的导航小助手,今...
安卓系统自带安装器,探索安卓系... 你有没有发现,每次手机更新系统后,安卓系统自带安装器就变得特别贴心呢?它就像你的私人助手,帮你轻松管...
张天灵安卓系统,引领智能生活新... 你知道吗?最近在手机圈里,有个名字可是火得一塌糊涂,那就是张天灵安卓系统。没错,就是那个让无数手机用...
安卓系统使用官方文档,系统架构... 你有没有想过,你的安卓手机里那些神奇的软件和功能,其实都是基于一个强大的系统——安卓系统?没错,就是...
安卓系统哪个系列最好,探索最佳... 你有没有想过,手机里的安卓系统就像是一群各具特色的英雄,每个系列都有它的独门绝技。那么,问题来了,安...
安卓修改系统时间设置,安卓系统... 你有没有发现,有时候手机上的时间总是和你心中的时间不太一样?是不是有时候你明明觉得才刚过中午,一看手...