当前位置:海洋目录网 » 站长资讯 » 教育考试 » 文章详细 订阅RssFeed

【springboot】使用redisson分布式锁

来源:本站原创 浏览:46次 时间:2022-12-08
redisson是基于redis之上的一款极具高性能、使用更便捷的综合中间件组件,本文记录使用redisson的分布式锁。前面介绍过使用redis实现的分布式锁:基于单节点redis实现分布式锁。

通常情况下redis都是集群部署的(这里不区分主从、哨兵、集群),在集群中通过setnx,del操作需要考虑更多的问题(如高并发下redis集群数据同步问题,集群宕机的问题等),正确的处理锁的安全性及活性,需要更复杂的操作,而使用redisson可以轻松搞定这一切。
下面使用redisson测试一下分布式锁的效果,引入pom依赖:

<dependency>
   <groupId>org.redisson</groupId>
   <artifactId>redisson</artifactId>
   <version>3.12.5</version>
</dependency>

本文使用springboot2,初始化redisson实例:

@Data
@Configuration
@ConfigurationProperties(prefix = "spring.redisson")
public class RedissonConfig {
   private String host;
   private String password;
   private int connectTimeout;
   @Bean
   public RedissonClient redissonClient(){
       Config config = new Config();
       config.setTransportMode(TransportMode.NIO);

       config.useSingleServer().setAddress(host)

        .setPassword(password).setConnectTimeout(connectTimeout);
       return

       return Redisson.create(config);
   }
}

相关yml属性如下(简略配置):

spring:
 redisson:
   host: redis://127.0.0.1:6379
   password: redis5
   connection-timeout: 5000

最后,测试验证一下基于单点redis分布式锁中的案例:

@GetMapping("hello")
public String hello() {
   CountDownLatch latch = new CountDownLatch(1000);
   RLock lock = redissonClient.getLock(KEY);
   for (int i = 0; i < 1000; i++) {
       new Thread(() -> {
           boolean res = false;
           try {
               res = lock.tryLock(100, 10, TimeUnit.SECONDS);
               if(res){
                   amount--;
               }
           }finally{
               lock.unlock();
           }
           latch.countDown();
       }).start();
   }
   latch.await();
   return "amount:" + amount;
}

多次测试数据正确无误,且请求处理效率要较之前的单点redis分布式锁更高效,编码更少,操作更简单。redisson强大之处远不止于分布式锁,还包括分布式集合、分布式对象、数据分片等,相关文档说明可参见:

redisson wiki

https://github.com/redisson/redisson/wiki


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net