使用Redis作为SpringBoot项目数据缓存

本文详细介绍如何在SpringBoot项目中使用Redis作为缓存框架,包括安装配置、整合步骤及自定义Key规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第十六章:使用Redis作为SpringBoot项目数据缓存

转载文章:http://www.jianshu.com/p/734d0e0419cb

恒宇少年关注

2017.04.17 23:20*字数 2407阅读 2788评论 5喜欢 20

我们平时在项目中设计数据访问的时候往往都是采用直接访问数据库,采用数据库连接池来实现,但是如果我们的项目访问量过大或者访问过于频繁,将会对我们的数据库带来很大的压力。为了解决这个问题从而redis数据库脱颖而出,redis数据库出现时是以非关系数据库的光环展示在广大程序猿的面前的,后来redis的迭代版本支持了缓存数据、登录session状态(分布式session共享)等。所以又被作为内存缓存的形式应用到大型企业级项目中。

本章目标

实现SpringBoot项目中整合Redis非关系数据库作为内存缓存框架,并测试数据读取源。

安装Redis

官网的redis仅支持Linux服务器的安装版本,由于开发人员都是在windows上工作,所以GitHub上的牛人基于linux平台下的Redis实现了windows版本。

下载Windows版本Redis

我们直接访问github网址:github.com/MSOpenTech/redis/releases,下载最新的windows X64版本的压缩包,如下图1所示:

图1

我们下载第二个就可以了,第一个是安装程序方式可以直接安装不过不太喜欢那种形式,第二个则是压缩包的形式解压完就可以用,第三、四个都是源码文件。下载完成后随便解压到我们的盘符内的文件即可,如下图2所示:

图2

开启Redis

解压完成后我们来开启Redis数据库,Redis数据库的默认端口是6379,如果已经被其他应用程序占用,请自行修改redis.windows.conf配置文件,修改位置如下图3所示:

图3

如果没有端口没有被占用,我们需要在cmd命令窗口执行运行Redis,我们首先使用cmd命令进入到Redis解压目录并且执行redis-server.exe redis.windows.conf命令即可,如下图4所示:

图4

可以看到上述图4,我们的redis数据库已经启动了,下面输出日志开启了服务链接在6379端口。好了我们的数据库已经配置完成了,接下来我们来构建SpringBoot整合Redis项目。

构建项目

我们使用IntelliJ IDEA工具构建一个SpringBoot项目,预先添加依赖Web、MySQL、JPA、Druid等。项目结构如下图5所示:

图5

接下来复制第十三章:SpringBoot实战SpringDataJPA文章项目源码(源码地址:git.oschina.net/jnyqy/lessons)的application.yml配置文件到本章节项目的resources目录下,如下图6所示:

图6

自行修改本地的数据库连接池的连接地址、用户名、密码就可以了。这个配置是我本地的!

配置支持Redis

构建完成后我们需要让我们的SpringBoot项目支持Redis数据库才能完成缓存的操作。

添加Redis依赖

我们打开pom.xml配置文件添加对应的redis缓存依赖maven配置,如下图7所示:

图7

我们添加缓存的支持需要两个依赖,一个是SpringBoot内部的缓存配置、另外则是我们的redis缓存。

配置Redis数据库

依赖添加完成后,需要配置我们本地的redis数据库连接到项目中,我们打开application.yml配置文件添加如下图8所示的配置内容:

图8

配置CacheManager

下面我们需要让SpringBoot内置的缓存框架使用我们的Redis作为新的缓存,我们来添加一个RedisConfiguration的配置类,并添加对应的配置如下图9所示:

图9

我们使用@EnableCaching注解来开启我们的项目支持缓存,我们在配置类内添加了方法cacheManager(),方法的返回值则是使用了我们的Redis缓存的管理器,SpringBoot项目启动时就会去找自定义配置的CacheManager对象并且自动应用到项目中。

上述就是有关Redis的所有配置,现在我们来编写一个测试的请求读取数据库内的单表数据,查看是否已经可以缓存数据。

使用Redis

我们现在我们本地的MySQL数据库内创建一张表结构,如下图10所示:

图10

表内就是几个简单的测试字段,下面我们根据对应的字段创建UserEntity,代码如下图11所示:

图11

截图省略了getter/setter,请自行添加上。下面我们根据UserEntity创建一个SpringDataJPA支持的JPA接口,(如需了解SpringDataJPA请访问:第十三章:SpringBoot实战SpringDataJPA)接口代码如下图12所示:

图12

创建JPA完成后,我们对应的创建一个业务逻辑服务类:UserService,我们在Service内添加redis的缓存支持,如下图13所示:

图13

在上图13内有两个新的注解,

@CacheConfig:该注解是用来开启声明的类参与缓存,如果方法内的@Cacheable注解没有添加key值,那么会自动使用cahceNames配置参数并且追加方法名。

@Cacheable:配置方法的缓存参数,可自定义缓存的key以及value。

再来添加一个名叫UserController的控制器,使用@RestController风格注解。如下图14所示:

图14

好了,下面我们来启动项目访问地址查看效果。

测试Redis

运行项目并查看控制台输出的日志是否存在异常,启动成功后访问地址:127.0.0.1:8080/list,界面输出内容如下图15所示:

图15

数据为测试数据,在启动项目之前需要手动添加到数据库。我们再来看下控制台输出的SQL,如下图16所示:

图16

可以看到是正常的访问数据库并且执行了JPA自动生成的SQL,那么为了验证Redis缓存,我们再来请求依次列表,界面输出内容如下图17所示:

图17

可以看到我们同样是可以访问到数据的,而且跟上次访问列表的数据一致,那么神奇的地方来了,我们去看下控制台的SQL输出,如下图18所示:

图18

可以看到只有一次输出,这个输出还是我们上次访问的时候执行的,证明我们配置的Redis缓存已经生效,下面我们使用Redis的客户端来查看下是否已经存在。

使用Redis-Cli客户端

我们使用Cmd命令进入我们的Redis解压目录,并执行redis-cli.exe应用程序,效果如下图19所示:

图19

可以看到Redis为我们自动生成的Key让我们很无奈,根本看不懂!那我们以后维护起来就很复杂了。下面我们来自定义Redis生成Key的规则!

自定义Key

我们打开RedisConfiguration配置类,添加继承CachingConfigurerSupport类,并重写方法keyGenerator(),代码如下图20所示:

图20

如上图20所述,我们根据类名、方法名、参数列表等完成自定义Redis缓存的Key定义,下面我们重启下项目,两次访问127.0.0.1:8080/list地址查看界面输出,如下图21所示:

图21

可以看到跟我们之前一样,第一次放了数据库,第二次查询了缓存数据,我们再来通过redis-cli客户端查看下数据库内保存的key是否已经按照我们自定义规则生成。如下图22所示:

图22

可以看到第二条,就是根据我们规则生成的key。

Redis命令

Redis数据库内有很多个命令下面我简单介绍几个大家在日常开发中常用到的。

flushdb:清空当前数据库。

select [index]:选择索引数据库,index为索引值名,如:select 1。

del [key]:删除一条指定key的值。

keys *:查看数据库内所有的key。

flushall:清空所有数据库。

quit:退出客户端连接。

总结

以上所述就是本章的全部讲解内容,本章主要讲解了SpringBoot项目中如何使用Redis非关系型数据库作为缓存框架,并完成自定义Redis生成的key值。

本章所用到的数据库已经放置到resources目录下,请访问码云下载。

本章代码已经上传到码云:

SpringBoot配套源码地址:https://gitee.com/hengboy/spring-boot-chapter

SpringCloud配套源码地址:https://gitee.com/hengboy/spring-cloud-chapter

SpringBoot相关系列文章请访问:目录:SpringBoot学习目录

QueryDSL相关系列文章请访问:QueryDSL通用查询框架学习目录

SpringDataJPA相关系列文章请访问:目录:SpringDataJPA学习目录

SpringBoot相关文章请访问:目录:SpringBoot学习目录,感谢阅读!

欢迎加入QQ技术交流群,共同进步。

QQ技术交流群

Spring Boot 企业级技术

© 著作权归作者所有

举报文章

<think>好的,我现在需要帮助用户解决在Spring Boot项目中集成和使用Redis作为缓存的问题。首先,我得回忆一下之前学过的相关知识,然后结合用户提供的引用内容来组织回答。 用户引用的内容里有几个关键点:添加依赖、配置Redis连接信息、创建RedisService类、使用@Cacheable注解以及RedisTemplate的操作。我需要确保这些步骤都被涵盖到,同结构要清晰,符合用户的要求。 首先,应该从添加依赖开始。用户提到引用[2]和[3]中都有提到添加依赖项,特别是spring-boot-starter-data-redis。这部分是基础,必须包括进去,并且给出具体的Maven或Gradle配置示例。 接下来是配置Redis连接信息。根据引用[2]和[4],需要在application.properties或application.yml中设置host、port、password等参数。这里要详细说明每个配置项的作用,以及如何根据实际情况修改。 然后,可能需要提到启用缓存支持,使用@EnableCaching注解,如引用[3]和[5]中所述。这一步很重要,否则缓存注解不会生效。 接下来是创建服务类并使用@Cacheable注解。引用[5]中的例子展示了如何在方法上使用该注解,指定缓存名称和键。需要解释这些参数的作用,并说明缓存的工作原理,比如当方法被调用,如何检查缓存是否存在,不存在则执行方法并将结果存入缓存。 此外,引用[4]提到了使用RedisTemplate,可能需要补充这部分内容。例如,配置RedisTemplate的序列化方式,避免存储乱码,以及如何通过RedisTemplate直接操作Redis,比如set、get等方法。不过用户的主要需求是缓存配置,这部分可以作为进阶内容简要提及。 还要注意引用[1]中提到的Spring Boot支持的缓存组件,这里需要确认Redis是其中之一,并且说明整合Redis的优势,比如高性能、持久化等。 用户的问题可能还包括如何验证配置是否成功,所以可以建议编写一个测试Controller,调用带有@Cacheable注解的方法,观察日志或使用Redis客户端工具检查数据是否被缓存。 需要确保回答符合用户的要求:结构清晰,分步骤说明,尽量真实可靠,引用正确的引用标记。例如,在提到配置连接信息,末尾添加[^2],提到@Cacheable引用[^3]和[^5]。 最后,生成的相关问题需要围绕集成Redis缓存可能遇到的扩展问题,比如配置过期间、缓存穿透/雪崩的解决方案、集群配置等,这些都能帮助用户进一步学习。 现在需要检查是否有遗漏的步骤,比如是否要提到缓存管理器(RedisCacheManager)的配置?根据引用[4]中的RedisConfig类,可能需要说明通过配置类自定义RedisTemplate的序列化方式,但如果是默认配置,可能不需要,除非用户有特殊需求。这里可能根据引用[4]的内容,简要提到配置RedisTemplate的示例,但用户主要关注的是基础配置,所以可能作为可选的高级配置部分。 总结回答的步骤应该是:添加依赖→配置连接→启用缓存使用注解→示例演示。此外,RedisTemplate的使用可以作为另一种操作方式补充,但重点在注解方式的缓存使用。</think>### Spring Boot集成Redis缓存配置教程 #### 1. 添加Redis依赖 在`pom.xml`中引入Spring Boot的Redis Starter依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 此依赖提供了RedisTemplate和缓存注解支持[^3]。 #### 2. 配置Redis连接信息 在`application.properties`中配置Redis服务器信息: ```properties spring.redis.host=localhost spring.redis.port=6379 spring.redis.password=your_password spring.redis.database=0 ``` 若使用连接池,可添加以下配置: ```properties spring.redis.lettuce.pool.max-active=8 spring.redis.lettuce.pool.max-idle=8 ``` #### 3. 启用缓存功能 在主启动类添加`@EnableCaching`注解: ```java @SpringBootApplication @EnableCaching public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 4. 使用@Cacheable注解缓存数据 在Service层方法上添加缓存注解: ```java @Service public class UserService { @Cacheable(value = "userCache", key = "#id") public User getUserById(Long id) { // 模拟数据库查询 return userRepository.findById(id).orElse(null); } } ``` - `value`指定缓存名称 - `key`使用SpEL表达式定义缓存键 #### 5. 自定义RedisTemplate(可选) 配置序列化方式避免乱码: ```java @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new GenericJackson2JsonRedisSerializer()); template.setConnectionFactory(factory); return template; } } ``` 此配置使键值对以JSON格式存储[^4]。 #### 6. 验证缓存效果 创建测试Controller: ```java @RestController public class TestController { @Autowired private UserService userService; @GetMapping("/user/{id}") public User getUser(@PathVariable Long id) { return userService.getUserById(id); } } ``` 首次访问会执行数据库查询,后续请求直接从Redis获取数据。 ### 关键配置说明 | 配置项 | 说明 | 示例值 | |----------------------------|-------------------------------|----------------| | spring.redis.host | Redis服务器地址 | 127.0.0.1 | | spring.redis.port | Redis服务端口 | 6379 | | spring.redis.password | 访问密码(无密码可省略) | your_password | | @Cacheable.cacheNames | 定义缓存分区名称 | "userCache" |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值