当前位置: 首页 > news >正文

Spring Cache:简化缓存管理的抽象框架

Spring Cache

Spring Cache是Spring框架提供的缓存抽象层,通过注解和自动化配置,简化应用中对缓存的操作,支持多种缓存实现(如Redis、Ehcache、Caffeine)。

1. 核心特性

  • 声明式缓存:通过注解(如@Cacheable、@CacheEvict)声明缓存行为,无需手动编写缓存逻辑。
  • 多缓存实现支持:兼容Redis、Ehcache、Caffeine等缓存工具,通过统一接口切换实现。
  • 与Spring无缝集成:基于AOP动态代理,拦截方法调用自动处理缓存。
  • 灵活的缓存策略:支持条件缓存(condition)、缓存键生成(key)、缓存过期等配置。

2. 核心注解

注解作用常用参数示例
@EnableCaching开启缓存注解功能,通常加在启动类上
@Cacheable方法结果缓存。在方法执行前先查询缓存中是否有数据,如果有数据则直接返回缓存数据;如果没有缓存数据,调用方法并将方法返回值放到缓存中value(缓存名)、key(键)、condition(条件)缓存数据库查询结果
@CachePut更新缓存,将方法的返回值放到缓存中value(缓存名)、key(键)、condition(条件)数据更新后刷新缓存
@CacheEvict删除缓存,将一条或多条数据从缓存中删除allEntries(清空所有键)、beforeInvocation(执行前删除)数据清除时删除缓存

1. @Cacheable:

       作用:标记方法的结果需要被缓存。当方法被调用时,先检查缓存是否存在对应键值,若存在则直接返回缓存值,否则执行方法并将结果存入缓存。

        使用场景:查询操作(如数据库查询、复杂计算等)。

        示例:

@Cacheable(value = "userCache", key = "#userId", condition = "#userId != null")
public User getUserById(Long userId) {
    return userRepository.findById(userId).orElse(null);
}

2. @CachePut:

        作用:更新缓存。无论缓存是否存在,都会执行方法,并将结果更新到缓存中。

        适用场景:新增或更新操作(如更新用户信息后同步缓存)。

        示例:

@CachePut(value = "userCache", key = "#user.id")
public User updateUser(User user) {
    return userRepository.save(user);
}

3. @CacheEvict

        作用:删除缓存。根据条件清除指定键或整个缓存区的数据。

        适用场景:删除操作(如用户删除后清理缓存)。

        示例:

@CacheEvict(value = "userCache", key = "#userId")
public void deleteUser(Long userId) {
    userRepository.deleteById(userId);
}

// 清空整个缓存区
@CacheEvict(value = "userCache", allEntries = true)
public void clearAllUserCache() {}

3.使用步骤(以Redis为例)

添加依赖:

<!-- Spring Boot Starter Cache -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<!-- Redis 集成 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置缓存类型与Redis:

# application.properties
spring.cache.type=redis
spring.redis.host=localhost
spring.redis.port=6379
# 可选:设置缓存过期时间(单位:毫秒)
spring.cache.redis.time-to-live=60000

启用缓存:在启动类添加@EnableCaching

@SpringBootApplication
@EnableCaching
public class MyApp { ... }

在Service层使用注解:

// 仅当参数id>10时缓存
@Cacheable(value = "users", condition = "#id > 10")

// 结果不为null时缓存
@Cacheable(value = "users", unless = "#result == null")

4. 缓存键与条件控制

自定义缓存键(SpEL表达式)

@Cacheable(value = "orders", key = "#userId + ':' + #status")
public List<Order> getOrdersByUserAndStatus(Long userId, String status) { ... }

条件缓存(condition和unless)

// 仅当参数id>10时缓存
@Cacheable(value = "users", condition = "#id > 10")

// 结果不为null时缓存
@Cacheable(value = "users", unless = "#result == null")

5. 适用场景

  1. 高频读低频写:如商品详情页、用户信息查询。
  2. 耗时计算:缓存复杂计算结果(如报表生成)。
  3. API限流:缓存接口调用次数。
  4. 会话管理:分布式环境下用户状态缓存。

Spring Cache通过简化缓存逻辑与代码解耦,显著提升了开发效率。结合Redis等高性能缓存工具,能够轻松应对高并发场景。

http://www.dtcms.com/a/99049.html

相关文章:

  • MCP, LangChain、Dify 区别
  • 3.30日 001:中央海岸VS珀斯光荣
  • 操作系统 :进程概念
  • 集多功能为一体的软件,支持批量操作。
  • web权限划分提权和移权
  • 自行车模型与汽车模型的混合策略在自动驾驶中的多维度协同优化
  • graylog使用过程中的几个问题
  • 根据二叉树创建字符串
  • Linux的进程优先级调度学习笔记
  • 智慧运维平台:赋能未来,开启高效运维新时代
  • React 中props的不可变性,如何在组件中处理需要修改props的情况?
  • 每日一题 MySQL基础知识----(三)
  • 饮食 “妙方”,助力进行性核上性麻痹调养
  • 学校智慧路灯的主要功能有哪些?
  • Python第六章19:函数的多种参数类型对比
  • 【嵌入式学习3】零散知识点
  • 【C++篇】类与对象(上篇):从面向过程到面向对象的跨越
  • 【8】递归之经典题型总结
  • Redis6数据结构之String类型
  • DeepSeek本地部署(linux)
  • 零基础驯服GitHub Pages
  • Linux进程管理之子进程的创建(fork函数)、子进程与线程的区别、fork函数的简单使用例子、子进程的典型应用场景、父进程等待子进程结束后自己再结束
  • Elasticsearch 高级
  • 分库分表策略
  • Flutter:切换账号功能记录
  • 【算法】动态规划:背包问题
  • HTTP---基础知识
  • python实现股票数据可视化
  • 【电子通识】案例:为什么电子产品制造过程中使用马克笔在FFC/FPC连接器打点进行标记
  • 去噪算法大比拼