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.操作视图接口
接口 | 描述 |
---|---|
GeoOperations | Redis的地理空间操作的,比如GEOADD,GEORADIUS… |
HashOperations | Redis哈希操作 |
HyperLogLogOperations | Redis的HyperLogLog操作,例如PFADD,PFCOUNT,… |
ListOperations | Redis设置操作 |
SetOperations | Redis的地理空间操作的,比如GEOADD,GEORADIUS… |
ValueOperations | Redis zset(或排序集)操作 |
ZSetOperations | Redis zset(或排序集)操作 |
关键绑定操作 | |
BoundGeoOperations | Redis键绑定地理空间操作 |
BoundHashOperations | Redis哈希键绑定操作 |
BoundKeyOperations | Redis键绑定操作 |
BoundListOperations | Redis列表键绑定操作 |
BoundSetOperations | Redis设置键绑定操作 |
BoundValueOperations | Redis字符串(或值)键绑定操作 |
BoundZSetOperations | Redis 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://i-blog.csdnimg.cn/blog_migrate/cd19b0c727572e3edad52d082d64eb03.png)
详细参考官方文档: https://docs.spring.io/spring-data/redis/docs/2.2.3.RELEASE/reference/html/#redis:template.