IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot 整合Redisson(*) -> 正文阅读

[Java知识库]SpringBoot 整合Redisson(*)

一、Redission整合

redission是一个redis客户端,用于分布式系统中
1、创建SpringBoot项目
  引入SpringBoot的redission启动器:

 <dependency>
     <groupId>org.redisson</groupId>
     <artifactId>redisson-spring-boot-starter</artifactId>
     <version>3.15.5</version>
 </dependency>

查看jar包相关依赖
在这里插入图片描述
2、配置redission

  1. 在application.yml 中添加redission 配置文件路径
spring:
   redis:
     database: 0
     timeout: 3000
     password: 
     # 单节点模式
     host: 127.0.0.1
     port: 6379
     # redisson配置文件路径
     redisson:
       file: classpath:redisson.yml
  1. 新建resources/redission.yml文件, 内容如下:
# 单节点配置
 singleServerConfig:
   # 连接空闲超时,单位:毫秒
   idleConnectionTimeout: 10000
   # 连接超时,单位:毫秒
   connectTimeout: 10000
   # 命令等待超时,单位:毫秒
   timeout: 3000
   # 命令失败重试次数,如果尝试达到 retryAttempts(命令失败重试次数) 仍然不能将命令发送至某个指定的节点时,将抛出错误。
   # 如果尝试在此限制之内发送成功,则开始启用 timeout(命令等待超时) 计时。
   retryAttempts: 3
   # 命令重试发送时间间隔,单位:毫秒
   retryInterval: 1500
   # 密码
   password:
   # 单个连接最大订阅数量
   subscriptionsPerConnection: 5
   # 客户端名称
   clientName: myredis
   # 节点地址
   address: redis://127.0.0.1:6379
   # 发布和订阅连接的最小空闲连接数
   subscriptionConnectionMinimumIdleSize: 1
   # 发布和订阅连接池大小
   subscriptionConnectionPoolSize: 50
   # 最小空闲连接数
   connectionMinimumIdleSize: 32
   # 连接池大小
   connectionPoolSize: 64
   # 数据库编号
   database: 0
   # DNS监测时间间隔,单位:毫秒
   dnsMonitoringInterval: 5000
 # 线程池数量,默认值: 当前处理核数量 * 2
 #threads: 0
 # Netty线程池数量,默认值: 当前处理核数量 * 2
 #nettyThreads: 0
 # 编码
 codec: !<org.redisson.codec.JsonJacksonCodec> {}
 # 传输模式
 transportMode : "NIO"

3、编辑启动类 和 配置类

  1. 主启动类 Application.java
 @SpringBootApplication
 public class Application {
 
     /**
      * 测试 Redis客户端 Redission 的使用
      * @param args
      */
     public static void main(String[] args) {
         SpringApplication.run(Application.class);
     }
 }
  1. 测试类 TestApplication.java
 package com.test.redis;
 
 import org.junit.Test;
 import org.junit.runner.RunWith;
 import org.redisson.api.RLock;
 import org.redisson.api.RedissonClient;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.test.context.SpringBootTest;
 import org.springframework.context.ApplicationContext;
 import org.springframework.test.context.junit4.SpringRunner;
 
 @RunWith(SpringRunner.class)
 @SpringBootTest
 public class TestApplication {
 
     @Autowired
     ApplicationContext context;
 
     // redisson客户端
     @Autowired
     RedissonClient redissonClient;
 
     // 测试分布式锁
     @Test
     public void terst1() throws InterruptedException {
         RLock lock = redissonClient.getLock("anyLock");
 
         new Thread(() -> {
             lock.lock();
 
             try {
                 System.out.println(Thread.currentThread().getName() + ":	 获得锁");
                 Thread.sleep(3000);
             } catch (InterruptedException e) {
                 e.printStackTrace();
             } finally {
                 System.out.println(Thread.currentThread().getName() + ":	 释放锁");
                 lock.unlock();
             }
         }).start();
 
 
         new Thread(() -> {
             lock.lock();
             try {
                 System.out.println(Thread.currentThread().getName() + ":	 获得锁");
                 Thread.sleep(3000);
             } catch (InterruptedException e) {
                 e.printStackTrace();
             } finally {
                 System.out.println(Thread.currentThread().getName() + ":	 释放锁");
                 lock.unlock();
             }
         }).start();
 
         Thread.sleep(100000);
     }
 }

4、测试运行
正常运行,且能加锁成功
控制台输出:
在这里插入图片描述
redis数据:
在这里插入图片描述
 分布式锁原理参考:【Redis】分布式锁之Redis实现

二、Redission整合原理

1、Redission的自动配置类 RedissonAutoConfiguration

 @Configuration
 @ConditionalOnClass({Redisson.class, RedisOperations.class})
 
 // @AutoConfigureBefore表示在 RedisAutoConfiguration 之前注入
 @AutoConfigureBefore(RedisAutoConfiguration.class)
 
 @EnableConfigurationProperties({RedissonProperties.class, RedisProperties.class})
 public class RedissonAutoConfiguration {
     ......
     
     // Redisson属性配置
     @Autowired
     private RedissonProperties redissonProperties;
     // Redis属性配置
     @Autowired
 
 
     // 注入了 redisTemplate
     @Bean
     @ConditionalOnMissingBean(name = "redisTemplate")
     public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
         RedisTemplate<Object, Object> template = new RedisTemplate<Object, Object>();
         template.setConnectionFactory(redisConnectionFactory);
         return template;
     }
 
     // 注入了 stringRedisTemplate
     @Bean
     @ConditionalOnMissingBean(StringRedisTemplate.class)
     public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
         StringRedisTemplate template = new StringRedisTemplate();
         template.setConnectionFactory(redisConnectionFactory);
         return template;
     }
 
     // 注入了 redissonConnectionFactory redission连接工厂
     @Bean
     @ConditionalOnMissingBean(RedisConnectionFactory.class)
     public RedissonConnectionFactory redissonConnectionFactory(RedissonClient redisson) {
         return new RedissonConnectionFactory(redisson);
     }
 
     // 注入了 RedissonClient 客户端
     @Bean(destroyMethod = "shutdown")
     @ConditionalOnMissingBean(RedissonClient.class)
     public RedissonClient redisson() throws IOException {
         Config config = null;
         ......
         return Redisson.create(config);
     }
     ......
 }
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-07-20 18:38:23  更:2022-07-20 18:38:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/21 15:56:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码