【Spring全家桶】Spring Cache 深度解析:一行注解实现缓存自动化

【Spring全家桶】Spring Cache 深度解析:一行注解实现缓存自动化

一、 为什么要使用 Spring Cache?

在传统的缓存开发中(如使用 Redis),我们需要在业务代码中手动编写逻辑:先查询缓存,如果没有再查询数据库,最后把结果放入缓存。这种做法会导致大量重复代码 ,且缓存逻辑与业务逻辑高度耦合

Spring Cache 通过 AOP(面向切面编程) 技术,将缓存逻辑从业务中剥离出来。你只需要在方法上加上简单的注解,即可实现缓存功能。


二、 核心架构与原理

Spring Cache 的核心思想是:在方法执行前检查缓存,执行后更新缓存。

  • CacheManager:缓存管理器,用于管理各种缓存组件(如 RedisCacheManager, EhCacheManager)。
  • Cache:缓存接口,定义了缓存的具体操作。

三、 快速上手:Spring Boot 整合 Redis 缓存

1. 添加依赖

pom.xml 中引入 Redis 缓存启动器:

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

2. 开启缓存支持

在 Spring Boot 启动类上添加 @EnableCaching 注解:

java 复制代码
@SpringBootApplication
@EnableCaching // 开启缓存功能
public class CacheApplication {
    public static void main(String[] args) {
        SpringApplication.run(CacheApplication.class, args);
    }
}

3. 在 Service 层使用注解

这是 Spring Cache 最核心的部分,主要使用以下三个注解:

① @Cacheable:触发查询缓存

常用于查询操作。先看缓存有没有,有则直接返回;没有则执行方法并存入缓存。

java 复制代码
@Cacheable(value = "pet", key = "#id")
public PetBean getPetById(Integer id) {
    System.out.println("查询数据库...");
    return petDao.findById(id);
}
② @CachePut:更新缓存

常用于新增或修改操作。方法一定会执行,并将结果同步到缓存中。

java 复制代码
@CachePut(value = "pet", key = "#pet.id")
public PetBean updatePet(PetBean pet) {
    petDao.update(pet);
    return pet;
}
③ @CacheEvict:清除缓存

常用于删除操作。

java 复制代码
@CacheEvict(value = "pet", key = "#id")
public void deletePet(Integer id) {
    petDao.deleteById(id);
}

四、 常用注解属性详解

属性 含义 示例
value/cacheNames 缓存名称(相当于 Redis 的前缀) value = "user"
key 缓存的 key,支持 SpEL 表达式 key = "#user.id"
condition 满足条件时才缓存 condition = "#id > 10"
unless 否定缓存(满足条件时不缓存) unless = "#result == null"

五、 避坑指南:Spring Cache 失效的场景

很多初学者会遇到"加了注解但缓存不生效"的问题,通常是以下原因:

  1. 内部调用 :同一个类中,A 方法调用加了缓存注解的 B 方法,缓存会失效。
    • 原因:Spring Cache 是基于 AOP 代理的,内部调用不经过代理类。
  2. 方法非 public :缓存注解只能用于 public 方法。
  3. 结果未实现序列化 :如果使用 Redis 存储,存入的对象必须实现 java.io.Serializable 接口。

六、 进阶配置:自定义过期时间

默认情况下 Redis 缓存是永久有效的。我们可以通过配置 RedisCacheConfiguration 来设置过期时间:

java 复制代码
@Configuration
public class MyCacheConfig {
    @Bean
    public RedisCacheConfiguration redisCacheConfiguration() {
        return RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofMinutes(30)) // 设置缓存过期时间 30 分钟
                .disableCachingNullValues();     // 不缓存空值
    }
}

七、 总结

Spring Cache 极大地简化了缓存开发,让我们可以专注于业务逻辑。在实际项目中,建议遵循以下原则:

  • 查询多、修改少的数据最适合使用缓存。
  • 一致性要求极高的数据慎用缓存。
  • 合理设置过期时间,防止 Redis 被冷数据撑爆。

下一篇预告:

我们将探讨 Spring Cache 如何配合 Jackson 解决缓存乱码问题 。如果你觉得这篇教程对你有帮助,欢迎 点赞、收藏、关注

作者: [CodeToGym]

相关推荐
缺点内向31 分钟前
C#: 告别繁琐!轻松移除Word文档中的文本与图片水印
c#·自动化·word·.net
机器视觉的发动机1 小时前
AI算力中心的能耗挑战与未来破局之路
开发语言·人工智能·自动化·视觉检测·机器视觉
IT陈图图1 小时前
CANN生态数据引擎:minddata的缓存策略与性能调优
缓存·cann
晚霞的不甘1 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
0思必得02 小时前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化
芷栀夏2 小时前
CANN开源实战:基于DrissionPage构建企业级网页自动化与数据采集系统
运维·人工智能·开源·自动化·cann
寄存器漫游者2 小时前
Linux 软件编程 - IO 编程
linux·运维·spring
我真会写代码3 小时前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design3 小时前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
鸽芷咕3 小时前
DrissionPage 成 CANN 仓库爆款自动化工具:背后原因何在?
运维·python·自动化·cann