Spring Cache-基于注解的缓存

Spring Cache 是 Spring 提供的缓存抽象框架,能够将数据缓存到内存或外部缓存中,减少数据库或远程服务的访问频率,从而显著提升应用性能。Spring Cache 通过注解的方式实现缓存逻辑,使用方便,支持多种缓存实现,例如 ConcurrentMapEhCacheRedis 等。

1. Spring Cache 介绍

1.1 简介

Spring Cache 的核心是缓存抽象,通过注解方式自动管理缓存内容。Spring Cache 的特点包括:

  1. 缓存抽象:Spring Cache 提供了统一的缓存 API,可以通过不同的缓存实现(如 Redis、EhCache)来存储数据。
  2. 简洁易用:只需简单的注解,开发者可以在业务逻辑代码中实现缓存。
  3. 支持多种缓存策略:支持多种缓存策略如自动刷新、过期、更新等,适合多种业务场景。
  4. 可扩展性:Spring Cache 支持多种第三方缓存库,允许在项目需求变化时灵活选择缓存策略。

1.2 依赖

java 复制代码
<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 Cache 提供了丰富的注解来控制缓存的不同操作,以下是常用的注解:

在spring boot项目中,使用缓存技术只需在项目中导入相关缓存技术的依赖包,并在启动类上使用@EnableCaching开启缓存支持即可。

例如,使用Redis作为缓存技术,只需要导入Spring data Redis的maven坐标即可。

2.1 @EnableCaching

@EnableCaching 是 Spring Cache 的入口注解,用于启用 Spring 的缓存功能。这个注解通常加在 Spring Boot 启动类上。

java 复制代码
@SpringBootApplication
@EnableCaching
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

2.2 @Cacheable

在方法执行前,spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据;若没有数据,调用方法并将方法返回值放到缓存中

  • 作用:将方法的返回结果进行缓存,以便下次使用相同参数调用时直接从缓存中获取。
  • 属性
    • value:指定缓存的名称。
    • key:缓存的键(可用 SpEL 表达式定义)。
    • condition:缓存条件,满足条件时才进行缓存。
java 复制代码
@Cacheable(value = "users", key = "#id")
public User getUserById(Long id) {
    // 从数据库获取用户信息
}

2.3 @CachePut

  • 作用:更新缓存,但不影响方法的正常调用。常用于修改或新增方法,保证缓存中的数据与数据库一致。
  • 属性
    • valuekey:同 @Cacheable,指定缓存的名称和键。
    • condition:缓存条件,满足条件时才进行缓存。
java 复制代码
@CachePut(value = "users", key = "#user.id")
public User updateUser(User user) {
    // 更新数据库中的用户信息
    return user;
}

**说明:**key的写法如下

#user.id : #user指的是方法形参的名称, id指的是user的id属性 , 也就是使用user的id属性作为key ;

#result.id : #result代表方法返回值,该表达式 代表以返回对象的id属性作为key ;

#p0.id:#p0指的是方法中的第一个参数,id指的是第一个参数的id属性,也就是使用第一个参数的id属性作为key ;

#a0.id:#a0指的是方法中的第一个参数,id指的是第一个参数的id属性,也就是使用第一个参数的id属性作为key ;

#root.args[0].id:#root.args[0]指的是方法中的第一个参数,id指的是第一个参数的id属性,也就是使用第一个参数

的id属性作为key ;

2.4 @CacheEvict

  • 作用:清除缓存,通常用于删除操作。
  • 属性
    • valuekey:指定缓存的名称和键。
    • allEntries:是否清除所有缓存内容,默认为 false。设置为 true 时会清除指定 value 中的所有缓存。
    • beforeInvocation:是否在方法调用前清除缓存,默认为 false(即方法执行后清除缓存)。
java 复制代码
@CacheEvict(value = "users", key = "#id")
public void deleteUser(Long id) {
    // 删除数据库中的用户信息
}

2.5 @Caching

当一个方法需要同时具备多种缓存操作时,可以用 @Caching 组合多个缓存注解。

java 复制代码
@Caching(
    put = { @CachePut(value = "users", key = "#user.id") },
    evict = { @CacheEvict(value = "usernames", key = "#user.username") }
)
public User updateUser(User user) {
    // 更新用户信息
    return user;
}
相关推荐
勇往直前plus6 小时前
从文件到屏幕:Python/java 字符编码、解码、文本处理的底层逻辑解析
java·开发语言·python
Drifter_yh12 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
鸽鸽程序猿12 小时前
【Redis】zset 类型介绍
数据库·redis·缓存
z玉无心12 小时前
Redis
数据库·redis·oracle
予枫的编程笔记12 小时前
【Redis核心原理篇2】Redis 单线程模型:为什么单线程还能这么快?
数据库·redis·缓存
希忘auto12 小时前
详解Redis之分布式锁
redis
fengxin_rou12 小时前
一文吃透 Redis 压缩列表、listpack 及哈希表扩容与并发查询
数据库·redis·散列表
莫寒清13 小时前
Spring MVC:@RequestParam 注解详解
java·spring·mvc
没有医保李先生14 小时前
字节对齐的总结
java·开发语言
甲枫叶15 小时前
【claude】Claude Code正式引入Git Worktree原生支持:Agent全面实现并行独立工作
java·人工智能·git·python·ai编程