Spring Data 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.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值