专栏首页JavaQ深入Spring Boot (十一):整合Redis详解

深入Spring Boot (十一):整合Redis详解

Spring Boot为Redis的Lettuce和Jedis客户端库提供了基本的自动配置,并且可以使用Spring Data Redis完成更多的操作。本篇将介绍如何整合Redis及使用Redis实现简单的查询缓存,主要包括以下7部分内容:

  1. 缓存
  2. Redis
  3. Lettuce
  4. Spring Data Redis
  5. Spring Cache
  6. 整合Redis
  7. 小结

缓存

个人理解的缓存是指用于存储频繁使用的数据的空间,关注点是存储数据的空间和使用频繁的数据。缓存技术,简单的说就是先从缓存中查询数据是否存在,存在则直接返回,不存在再执行相应的操作获取数据,并将获取的数据存储到缓存中,它是一种提升系统性能的重要方法。

Redis

Redis是一个开源的、内存存储key-value类型的数据结构服务器,可用作数据库、高速缓存和消息队列代理。它支持的数据类型有字符串、哈希表、列表、集合、有序集合等,同时通过Redis Sentinel提供高可用,通过Redis Cluster提供分区功能。

Lettuce

Lettuce是一种可伸缩、线程安全、完全非阻塞的Redis客户端,多个线程可以共享同一个RedisConnection。它利用Netty NIO框架来高效地管理多个连接,从而提供了异步和同步数据访问方式,用于构建非阻塞的反应性应用程序。 整合Redis,可以通过使用spring-boot-starter-data-redis,这种方式下,Spring Boot默认使用的Redis客户端是Lettuce。

Spring Data Redis

Spring Data是Spring的一个主要项目,目的是为了简化构建基于Spring框架应用的数据访问,包括非关系数据库、Map-Reduce框架、云数据服务等,另外也包含对关系数据库的访问支持。Spring Data Redis是Spring Data项目中的一个主要模块,它提供了从Spring应用程序中轻松配置和访问Redis的功能、提供了与应用交互的低级和高级抽象,使开发者摆脱了对基础结构的关注,例如提供了RedisCacheManager。

Spring Cache

从Spring3.1开始,Spring框架提供了对Cache的支持,提供了一个对缓存使用的抽象,通过在既有代码中添加少量它定义的各种annotation,即能够达到缓存方法的返回对象的作用。提供的主要注解有@Cacheable、@CachePut、@CacheEvict和@Caching,具体见表1。

@Cacheable的常用属性及说明如表2所示。

SpEL表达式可以获取的值如表3所示。

@CachePut的常用属性同@Cacheable。 @CacheEvict的常用属性见表4。

当需要在类上或方法上同时使用多个注解时,可以使用@Caching,如@Caching(cacheable = @Cacheable("User"), evict = {@CacheEvict("Member"), @CacheEvict(value = "Customer", allEntries = true)})

整合Redis

在pom.xml或build.gradle中添加spring-boot-starter-data-redis依赖即可,默认使用Lettuce客户端,依赖管理将会自动下载Lettuce对应的jar,例如在build.gradle文件中添加如下依赖:

compile group: 'org.springframework.boot', name: 'spring-boot-starter-data-redis', version: '2.0.0.RELEASE'

在application.properties或application.yml中添加Redis服务配置,例如在application.properties中添加如下基础配置:

#Redis服务器主机地址 spring.redis.host=127.0.0.1 #Redis服务连接密码 spring.redis.password=123456 #Redis对外服务端口 spring.redis.port=6379

更多Redis的高级配置(哨兵模式、主从)可以在spring-boot-autoconfigure包的spring-configuration-metadata.json中查看。

编写业务代码实现简单的查询缓存:

@Service public class BankServiceImpl implements BankService { @Autowired private BankMapper bankMapper; @Cacheable(value = "bank", key = "'BankId_' + #id", condition = "#id<=100") @Override public Bank findBy(Long id) { return bankMapper.findById(id); } }

在application.properties或application.yml中配置一些缓存的配置,例如在application.properties添加如下配置:

#在写入Redis时是否要使用key前缀 spring.cache.redis.use-key-prefix=true #key前缀 spring.cache.redis.key-prefix=banks_ #是否允许null值 spring.cache.redis.cache-null-values=false #缓存有效时间,单位毫秒,默认长久有效 spring.cache.redis.time-to-live=5000

小结

当Redis可用并正确配置,应用启动时,Spring Boot会自动配置一个RedisCacheManager,这个CacheManager会在第一次写入时默认创建缓存。上面的查询缓存代码只是一个简单的Redis使用示例,当然你也可以在代码中自动注入RedisConnectionFactory、StringRedisTemplate或RedisTemplate实例,使用它们完成更多的扩展需求。

为了更方便的技术交流,建了一个微信群,加博主微信wind7rui,邀你进群!

END

如果觉得有收获,记得关注、点赞、转发。

本文分享自微信公众号 - JavaQ(Java-Q),作者:wind瑞

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-03-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 大厂都聊分布式系统,面试不知道分布式锁如何聊下去

    公众号[JavaQ]原创,专注分享Java基础原理分析、实战技术、微服务架构、分布式系统构建,诚邀点赞关注!

    JavaQ
  • 高并发编程-CountDownLatch深入解析

    CountDownLatch允许一个或者多个线程一直等待,直到一组其它操作执行完成。在使用CountDownLatch时,需要指定一个整数值,此值是线程将要等待...

    JavaQ
  • 分布式锁那点事

    分布式锁是控制分布式系统之间同步访问共享资源的一种方式。本篇将详细分析分布式锁的三种实现方式及其优化方案,分析其优缺点。 为什么要使用分布式锁 为了保证一个方...

    JavaQ
  • 解锁Spring Data Redis的正确使用姿势

    Redis 是一个开源的使用 ANSIC 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从2010年...

    CSDN技术头条
  • 数据缓存之Reids

    什么是Redis?在百度百科中给了如下定义:“Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,...

    申霖
  • Redis服务器被攻击后该如何安全加固

    在特定条件下,如果 Redis 以 root 身份运行,黑客可以给 root 账号写入 SSH 公钥文件,直接通过 SSH 登录受害服务器,从而获取服务器权限和...

    搜云库技术团队
  • 单线程Redis性能为何如此之高?

    实际项目开发中现在无法逃避的一个问题就是缓存问题,而缓存问题也是面试必问知识点之一,如果面试官好一点可能会简单的问你二八定律或者热数据和冷数据,但是如果问的深入...

    逆月翎
  • Redis的5个常见应用场景

    前言 Redis 是一个强大的内存型存储,具有丰富的数据结构,使其可以应用于很多方面,包括作为数据库、缓存、消息队列等等。 如果你的印象中Redis只是一个 k...

    dys
  • 你以为你会 Redis,其实呢?

    今天给大家推荐一本书《Redis 深度历险:核心原理与应用实践》,作者钱文品,想必大家也不陌生,前几天网上非常火的掘金小册子,1.7W 的购买量,你就知道这书的...

    用户1093975
  • Redis的高级特性一览

    慢查询只记录Redis在处理存储的时间计数(图中的3步骤),并不包含网络通信时间和排队时间,所以客户端超时分析时要综合每个因素。

    全菜工程师小辉

扫码关注云+社区

领取腾讯云代金券