Spring Data Redis

本文介绍SpringDataRedis在Spring应用中的简单配置与使用方法,包括添加启动器、配置文件、哈希映射策略及RedisTemplate的高级功能。通过实例演示如何高效操作Redis数据。

Spring Data Redis

简介

Spring-data-redis 是 spring 大家族的一部分,提供了在 srping 应用中通过简单的配置访问 redis 服务,对 reids 底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate 提供了 redis 各种操作、异常处理及序列化,支持发布订阅,并对 spring 3.1 cache 进行了实现。

1. Redis支持

Spring Data支持的键值存储之一是Redis。引用Redis项目主页:Redis是高级键值存储。它类似于memcached,但数据集不是易失的,值可以是字符串,就像在memcached中一样,也可以是列表,集合和有序集合。所有这些数据类型都可以用原子操作进行操作,以推入/弹出元素,添加/删除元素,执行服务器端联合,交集,集合之间的差异等。Redis支持不同种类的排序功能。

2.添加相关启动器Lombok、Spring Data Redis、spring-data-common

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- 使用spring-data-common -->
<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-commons</artifactId>
    <version>2.2.0.RELEASE</version>
</dependency>
<!-- 添加jedis依赖 -->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>3.0.1</version>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
    <exclusions>
        <exclusion>
            <groupId>org.junit.vintage</groupId>
            <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
    </exclusions>
</dependency>

4. 在resources下新建redis-config. properties文件并加入redis相关配置

# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host-name=49.232.162.73
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制)
spring.redis.pool.max-active=100
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.pool.max-wait=10000
# 连接池中的最大空闲连接
spring.redis.pool.max-idle=8
# 连接池中的最小空闲连接
spring.redis.pool.min-idle=5
# 连接超时时间(毫秒)
spring.redis.timeout=1000000
## 最大连接数
spring.redis.pool.max-total=200

5.哈希映射

可以通过在Redis中使用各种数据结构来存储数据。Jackson2JsonRedisSerializer可以转换为JSON格式的对象。理想情况下,可以使用纯键将JSON存储为值。您可以使用Redis哈希来实现结构化对象的更复杂映射。Spring Data Redis提供了各种将数据映射到哈希的策略(取决于用例):

  • 通过使用HashOperations和序列化器直接映射
  • 使用Redis仓库
  • 使用HashMapper和HashOperations

6.哈希映射器

哈希映射器是映射对象到a Map<K, V>和back的转换器。HashMapper适用于Redis哈希。
有多种实现方式:

  • BeanUtilsHashMapper使用Spring的BeanUtils。
  • ObjectHashMapper使用对象到哈希映射。
  • Jackson2HashMapper使用FasterXML Jackson。

7.通过RedisTemplate处理对象

大多数用户可能会使用RedisTemplate及其相应的软件包org.springframework.data.redis.core。实际上,由于模板具有丰富的功能集,因此它是Redis模块的中心类。该模板为Redis交互提供了高级抽象。虽然RedisConnection提供了接受和返回二进制值(byte数组)的低级方法,但是模板负责序列化和连接管理,使用户无需处理此类细节。此外,该模板提供了操作视图(根据Redis命令参考进行分组),提供了丰富的,通用的接口,用于针对某种类型或某些键(通过KeyBound接口),如下表所述:

表1.操作视图接口
接口描述
GeoOperationsRedis的地理空间操作的,比如GEOADD,GEORADIUS…
HashOperationsRedis哈希操作
HyperLogLogOperationsRedis的HyperLogLog操作,例如PFADD,PFCOUNT,…
ListOperationsRedis设置操作
SetOperationsRedis的地理空间操作的,比如GEOADD,GEORADIUS…
ValueOperationsRedis zset(或排序集)操作
ZSetOperationsRedis zset(或排序集)操作
关键绑定操作
BoundGeoOperationsRedis键绑定地理空间操作
BoundHashOperationsRedis哈希键绑定操作
BoundKeyOperationsRedis键绑定操作
BoundListOperationsRedis列表键绑定操作
BoundSetOperationsRedis设置键绑定操作
BoundValueOperationsRedis字符串(或值)键绑定操作
BoundZSetOperationsRedis zset(或排序集)键绑定操作

8.RedisConnection和RedisConnectionFactory

  • RedisConnection提供了Redis通信的核心构建块,因为它处理与Redis后端的通信。它还会自动将基础连接库异常转换为Spring一致的DAO异常层次结构,以便您可以在不更改任何代码的情况下切换连接器,因为操作语义保持不变。
  • 对于需要本机库API的特殊情况,请RedisConnection提供专用方法(getNativeConnection),该方法返回用于通信的原始基础对象。
  • RedisConnection对象是通过创建的RedisConnectionFactory。另外,工厂充当PersistenceExceptionTranslator对象,这意味着一旦声明,它们就可以让您进行透明的异常转换。例如,您可以通过使用@Repository批注和AOP 进行异常转换。有关更多信息,请参见Spring Framework文档中的专用部分。
  • 根据基础配置,工厂可以返回新连接或现有连接(使用池或共享本机连接时)。
  • 使用的最简单方法RedisConnectionFactory是通过IoC容器配置适当的连接器,并将其注入using类。
    -不幸的是,当前,并非所有连接器都支持所有Redis功能。在基础库不支持的Connection API上调用方法时,将UnsupportedOperationException引发。

9.Spring Data Redis源码解析图在这里插入图片描述

详细参考官方文档: https://docs.spring.io/spring-data/redis/docs/2.2.3.RELEASE/reference/html/#redis:template.

### 配置Spring Data Redis 在使用 Spring Data Redis 之前,首先需要在项目中添加相应的依赖。以 Maven 为例,可以在 `pom.xml` 文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 此外,还需要选择一个 Redis 客户端库,例如 Lettuce 或 Jedis。Lettuce 是推荐的选择,因为它支持异步和响应式编程模型。以下是添加 Lettuce 依赖的示例: ```xml <dependency> <groupId>io.lettuce.core</groupId> <artifactId>lettuce-core</artifactId> <version>6.1.4</version> </dependency> ``` ### 连接配置 Spring Data Redis 的连接配置可以通过 `application.properties` 或 `application.yml` 文件进行设置。以下是一个基本的配置示例: ```properties spring.data.redis.host=127.0.0.1 spring.data.redis.port=6379 spring.data.redis.client-type=lettuce ``` 如果使用 YAML 格式,配置如下: ```yaml spring: data: redis: host: 127.0.0.1 port: 6379 client-type: lettuce ``` 这些配置项指定了 Redis 服务器的主机地址、端口号以及使用的客户端类型。 ### 序列化与反序列化 Spring Data Redis 在与 Redis 进行数据交互时,需要对 key 和 value 进行序列化和反序列化操作。为了确保数据能够正确地存储和读取,可以选择合适的序列化方式。常见的序列化方式包括 String、JDK、Jackson 等。根据实际需求,通常建议 key 使用 `StringRedisSerializer`,而 value 使用 `Jackson2JsonRedisSerializer`。以下是如何配置这两种序列化的示例代码: ```java @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new Jackson2JsonRedisSerializer<>(Object.class, "utf-8")); return template; } } ``` ### 基本操作 一旦配置完成,就可以通过 `RedisTemplate` 或 `StringRedisTemplate` 来执行各种 Redis 操作。以下是一些常用的操作示例: #### 存储和获取数据 ```java @Autowired private RedisTemplate<String, Object> redisTemplate; // 存储数据 redisTemplate.opsForValue().set("key", "value"); // 获取数据 String value = (String) redisTemplate.opsForValue().get("key"); ``` #### 发布订阅模式 Spring Data Redis 支持发布/订阅模式,允许你在不同的组件之间传递消息。以下是如何实现发布和订阅的示例: **定义监听器** ```java @Component public class RedisMessageListener implements MessageListener { @Override public void onMessage(Message message, byte[] pattern) { System.out.println("Received message: " + message.toString()); } } ``` **注册监听器** ```java @Configuration public class RedisPubSubConfig { @Autowired private RedisConnectionFactory redisConnectionFactory; @Bean public RedisMessageListenerContainer redisContainer() { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(redisConnectionFactory); container.addMessageListener(new RedisMessageListener(), new PatternTopic("channel")); return container; } } ``` **发布消息** ```java @Autowired private RedisTemplate<String, Object> redisTemplate; // 发布消息 redisTemplate.convertAndSend("channel", "Hello, Redis!"); ``` ### 高级功能集成 除了基本的数据操作外,Spring Data Redis 还支持许多高级功能,如与 Spring Cache 集成、Redis 持久化等。通过这些功能,可以更方便地管理缓存,并提高应用程序的性能。 #### 与 Spring Cache 集成 要将 Spring Data RedisSpring Cache 集成,只需在配置类中启用缓存并指定 Redis 作为缓存提供者: ```java @Configuration @EnableCaching public class CacheConfig extends CachingConfigurerSupport { @Bean public CacheManager cacheManager(RedisConnectionFactory factory) { RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig() .entryTtl(Duration.ofMinutes(1)); // 设置缓存过期时间为1分钟 return RedisCacheManager.builder(factory) .cacheDefaults(config) .build(); } } ``` #### Redis 持久化 Redis 提供了多种持久化机制,如 RDB(Redis Database Backup)和 AOF(Append Only File)。RDB 是一种快照式的持久化方式,适用于灾难恢复;AOF 则记录了所有写操作命令,适合于保证数据完整性。可以通过修改 Redis 配置文件来启用这些持久化方式。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值