服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - SpringBoot整合分布式锁redisson的示例代码

SpringBoot整合分布式锁redisson的示例代码

2023-03-05 15:02梁山教父 Java教程

这篇文章主要介绍了SpringBoot整合分布式锁redisson,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1、导入maven坐标

<!-- 用redisson作为所有分布式锁,分布式对象等功能框架-->
  <dependency>
      <groupId>org.redisson</groupId>
      <artifactId>redisson</artifactId>
      <version>3.12.5</version>
  </dependency>

 

2、redisson配置类(如果redis没有密码就不需要private String password)

package com.xuechengpluscommon.config;

import org.redisson.Redisson;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;
import org.redisson.config.SingleServerConfig;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
* @description Redisson 配置类
*/
@Configuration
public class MyRedissonConfig {

  @Value(value = "${spring.redis.host}")
  private String host;
  @Value(value = "${spring.redis.port}")
  private int port;
  @Value(value = "${spring.redis.database}")
  private int database;
//    @Value(value = "${spring.redis.password}")
//    private String password;

  /**
   * 单Redis节点模式配置方法
   * 其他配置參數,看:
   * <a href = "https://github.com/redisson/redisson/wiki/2.-%E9%85%8D%E7%BD%AE%E6%96%B9%E6%B3%95#26-%E5%8D%95redis%E8%8A%82%E7%82%B9%E6%A8%A1%E5%BC%8F">
   * 单Redis节点模式配置方法
   * </a>
   *
   * @return {@link RedissonClient}
   */
  @Bean(destroyMethod = "shutdown")
  RedissonClient redisson() {
      Config config = new Config();
      //Redis多节点
      // config.useClusterServers()
      //     .addNodeAddress("redis://127.0.0.1:6379", "redis://127.0.0.1:7001");
      //Redis单节点
      SingleServerConfig singleServerConfig = config.useSingleServer();
      //可以用"rediss://"来启用SSL连接
      String address = "redis://" + host + ":" + port;
      singleServerConfig.setAddress(address);
      //设置 数据库编号
      singleServerConfig.setDatabase(database);
//        singleServerConfig.setPassword(password);
      //连接池大小:默认值:64
      // singleServerConfig.setConnectionPoolSize()
      return Redisson.create(config);
  }

}

yml中redis的配置

redis:
  database: 0
  host: ip地址
  port: 6379

 

3、创建redisson的bean

@Autowired
private RedissonClient redisson;

 

4、测试. 入队

@Test
void contextLoads1() {
  RQueue<String> queue = redisson.getQueue("RedissonQueue");
  queue.add("hello");
  System.out.println(queue);
}

redis数据

SpringBoot整合分布式锁redisson的示例代码

 

5、测试. 出队

@Test
void contextLoads2() {
  RQueue<String> queue = redisson.getQueue("RedissonQueue");
  String remove = queue.remove();
  System.out.println(remove);
}

出队数据:

SpringBoot整合分布式锁redisson的示例代码

 

6、分布式锁

public R redisTest1() throws InterruptedException {
      //首先从redis查询数据
      Orders redisOrder;
      redisOrder=(Orders) redisTemplate.opsForValue().get("redisTest");
      //如果存在redis则返回
      if(ObjectUtils.isNotEmpty(redisOrder)){
          return R.ok(redisOrder);
          //如果不存在则从数据库查询
      }else {
          //首先获取分布式锁
          RLock lock = redissonClient.getLock("redisTestDogWatch");
          //上锁
          lock.lock();

          //获取锁之后进行查询
          try {
              redisOrder = (Orders) redisTemplate.opsForValue().get("redisTest");
              if (ObjectUtils.isNotEmpty(redisOrder)) {
                  return R.ok(redisOrder);
              }
              //数据库查询
              redisOrder= ordersService.getById(1577177773194113014L);
              redisTemplate.opsForValue().set("redisTest", redisOrder );
              System.out.println("[从数据库中查询]");

          } catch (Exception e) {
              e.printStackTrace();
          } finally {
              //删除锁
              lock.unlock();
          }
          return R.ok(redisOrder);
      }
  }

在这里让线程睡眠35秒

//上锁
lock.lock();
Thread.sleep(35000);

此时三个服务器运行

SpringBoot整合分布式锁redisson的示例代码

测试结果

可以首先看到已经上锁的redisTestDogWatch,每个锁30秒,如果线程未完成则会自动续30秒,如果线程完成到finally中的unlock就删除锁

SpringBoot整合分布式锁redisson的示例代码

目前可以看到只有一个服务器获取到锁

SpringBoot整合分布式锁redisson的示例代码

存储redis的数据

SpringBoot整合分布式锁redisson的示例代码

此时进行并发测试

SpringBoot整合分布式锁redisson的示例代码

依旧保持35秒的睡眠时间

此时可以看到未拿到锁的线程报错

java.lang.IllegalMonitorStateException: attempt to unlock lock, not locked by current thread by node id: d904f2b9-e75d-472d-a5a6-d0a8cc603a80 thread-id: 210

尝试解锁锁定,未被当前线程锁定 按节点 ID:C731FAC4-9BF7-4F4A-ACC1-A2CC9B78A02F 线程 ID:232

这是因为锁住了,所以无法获取锁,然后看门狗会不断刷新

SpringBoot整合分布式锁redisson的示例代码

到此这篇关于SpringBoot整合分布式锁redisson的文章就介绍到这了,更多相关SpringBoot整合分布式锁redisson内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_55127182/article/details/129125249

延伸 · 阅读

精彩推荐
  • Java教程关于idea中Java Web项目的访问路径问题

    关于idea中Java Web项目的访问路径问题

    这篇文章主要介绍了idea中Java Web项目的访问路径问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    WinstonLau7902021-08-29
  • Java教程详解使用Spring Security进行自动登录验证

    详解使用Spring Security进行自动登录验证

    本篇文章主要介绍了详解使用Spring Security进行自动登录验证,非常具有实用价值,需要的朋友可以参考下...

    木梨轻4392021-01-10
  • Java教程一次Jvm old过高的排查过程实战记录

    一次Jvm old过高的排查过程实战记录

    这篇文章主要给大家介绍了一次Jvm old过高的排查过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们...

    小草莓子桑11282021-06-10
  • Java教程基于Java Callable接口实现线程代码实例

    基于Java Callable接口实现线程代码实例

    这篇文章主要介绍了基于Java Callable接口实现线程代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    javase-->2822020-08-21
  • Java教程spring cloud zuul修改请求url的方法

    spring cloud zuul修改请求url的方法

    这篇文章主要给大家介绍了关于spring cloud zuul修改请求url的方法,文中通过示例代码介绍的非常详细,对大家学习或者使用spring cloud具有一定的参考学习价...

    xixicat8292021-01-01
  • Java教程举例讲解Java中的Stream流概念

    举例讲解Java中的Stream流概念

    这篇文章主要介绍了举例讲解Java中的Stream流概念,是Java入门学习中的基础知识,需要的朋友可以参考下 ...

    goldensun3422020-01-04
  • Java教程java简单实现自定义日历

    java简单实现自定义日历

    这篇文章主要为大家详细介绍了java简单实现自定义日历,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    hellolxb6352022-12-08
  • Java教程spring boot 部署为jar包的方法示例

    spring boot 部署为jar包的方法示例

    本篇文章主要介绍了spring boot 部署为jar的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    Ryan.Miao12062021-01-25