Spring环境下使用基于redis的分布式锁-注解方式

Spring下使用,基于redis的分布式锁-注解方式

代码工程地址:
https://github.com/AnzLee/distributed-lock

使用方法

1、拉取源码后使用maven命令打包

    mvn clean package

2、引入到自己的maven工程中

    <dependency>
        <groupId>com.github.anzlee</groupId>
        <artifactId>distributed-lock</artifactId>
        <version>1.0</version>
    </dependency>

3、在需要使用分布式锁的方法上加上注解@Lock即可

    @RestController
    @RequestMapping("test")
    public class TestController {
    
        /**
         * 接口
         * @return
         */
        @RequestMapping(value = "", method = RequestMethod.GET)
        @Lock
        public Response<Object> test(){
            return new Response<>();
        }
    
    }
该工程只适用于spring工程,如果不是spring工程,可以参考com.github.anzlee.lock.redisson.DistributedRedisLock类使用lockunlock方法对代码块加解锁

redisson实现原理


  • 加锁

      1、判断有没有${key}
    
      2、如果没有,则在其下设置一个字段为“hash:Thread-1”,值为“1”的键值对 ,并设置它的过期时间
    
      3、如果存在,则进一步判断“hash:Thread-1”是否存在,若存在,则其值加1,并重新设置过期时间
    
      4、返回${key}的生存时间(毫秒)
    
  • 解锁

      1、判断是否存在${key}
    
      2、如果不存在,向Channel中广播一条消息,广播的内容是0,并返回1
    
      3、如果存在,进一步判断字段hash:Thread-1是否存在
    
      4、若字段不存在,返回空,若字段存在,则字段值减1
    
      5、若减完以后,字段值仍大于0,则返回0
    
      6、减完后,若字段值小于或等于0,则广播一条消息,广播内容是0,并返回1;
    
  • 等待

      1、当无法立即获取到锁的时候,订阅Channel,当资源可用时可以及时知道,并抢占,防止无效的轮询而浪费资源
      
      2、当资源可用用的时候,循环去尝试获取锁,由于多个线程同时去竞争资源,所以这里用了信号量,对于同一个资源只允许一个线程获得锁,其它的线程阻塞
    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AnzLee888

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值