Springboot缓存注解详细介绍

本文详细介绍了Springboot中缓存的作用,重点讲解了CacheManager如何管理多个Cache组件,以及@Cacheable、@CachePut和@CacheEvict三个关键缓存注解的使用方法,包括它们各自的配置参数和应用场景。

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

1.缓存的作用

将方法的运行结果进行缓存,以后再要相同的数据,直接从缓存中获取,不用调用方法,进而提升加载速度

2.CacheManager

  1. CacheManager管理多个Cache组件,对缓存真正CRUD操作在Cache组件中,每一个缓存组件有自己唯一一个名字
  2. 容器中有一个默认的CacheManager:ConcurrentMapCacheManager
  3. 开发人员可以获取和创建ConcurrentMapCache类型的缓存组件;他的作用将数据保存在ConcurrentMap中

3.缓存注解

@Cacheable:

  1. 标注的方法执行之前先来检查缓存中有没有这个数据,默认按照参数的值作为key去查询缓存,如果没有就运行方法并将结果放入缓存;以后再来调用就可以直接使用缓存中的数据;
  2. cacheNames/value:指定缓存组件的名字;将方法的返回结果放在哪个缓存中,是数组的方式,可以指定多个缓存;
  3. key:缓存数据使用的key;可以用它来指定。默认是使用方法参数的值 1-方法的返回值
    •   编写SpEL; #id;参数id的值   #a0  #p0  #root.args[0]
      
    •   getEmp[2]
      
  4. keyGenerator:key的生成器;可以自己指定key的生成器的组件id
    •    key/keyGenerator:二选一使用;
      
  5. cacheManager:指定缓存管理器;或者cacheResolver指定获取解析器
  6. condition:指定符合条件的情况下才缓存;
    •    condition = "#id>0"
      
    •     condition = "#a0>1":第一个参数的值》1的时候才进行缓存
      
  7. unless:否定缓存;当unless指定的条件为true,方法的返回值就不会被缓存;可以获取到结果进行判断
    •  unless = "#result == null"
      
    •  unless = "#a0==2":如果第一个参数的值是2,结果不缓存;
      
  8. sync:是否使用异步模式

@CachePut

既调用方法,又更新缓存数据;同步更新缓存,修改了数据库的某个数据,同时更新缓存

运行时机:

	1.先调用目标方法
	2.将目标方法的结果缓存起来		   

@CacheEvict

缓存清除
key:指定要清除的数据

	   *  allEntries = true:指定清除这个缓存中所有的数据
 	   *  beforeInvocation = false:缓存的清除是否在方法之前执行
       *  默认代表缓存清除操作是在方法执行之后执行;如果出现异常缓存就不会清除
       *  beforeInvocation = true:
       *  代表清除缓存操作是在方法运行之前执行,无论方法是否出现异常,缓存都清除
### Spring Boot缓存注解及其使用方法 #### @EnableCaching 注解 为了使Spring应用能够支持声明式的缓存特性,需要在配置类上添加`@EnableCaching`注解。这会激活底层代理机制来拦截被标记的方法调用,并处理缓存逻辑[^3]。 ```java @Configuration @EnableCaching public class CacheConfig { // 配置内容... } ``` #### @Cacheable 注解注解用于标注那些其返回结果会被加入到缓存中的方法。每当执行该操作前都会先查询是否有符合条件的数据存在于缓存之中;如果有,则直接返回已有的数据而不再真正去运行这个方法体内的代码。可以通过设置value/key/condition等参数来自定义缓存策略[^1]。 - `value`: 指定要使用的缓存名称。 - `key`: 定义唯一标识符,默认情况下是根据传入参数生成的哈希值。 - `condition`: 表达式,在满足条件时才进行缓存。 ```java @Service public class BookService { private final Logger logger = LoggerFactory.getLogger(this.getClass()); @Cacheable(value="books", key="#id") public String findBookById(Long id){ logger.info("查找书籍ID:" + id); return "book-" + id; } } ``` #### @CachePut 注解 更新现有条目而不影响其他行为的方式之一就是利用`@CachePut`。这意味着每次触发带有此类标签的方法之后都将刷新关联项的内容,即使输入相同的参数也不会阻止实际函数被执行。 ```java @CachePut(value="books", key="#result.id") public Book update(Book book) { ... } ``` #### @CacheEvict 注解 清除特定条件下匹配的所有记录可借助于`@CacheEvict`完成。allEntries=true表示清空整个命名空间下的所有元素;beforeInvocation=true则是在方法之前就移除缓存而不是等待正常结束后再做清理工作。 ```java @CacheEvict(value="books", allEntries=true, beforeInvocation=true) public void deleteAllBooks() {...} // 或者仅删除单个实体对应的缓存 @CacheEvict(value="books", key="#id") public void removeBook(long id){...} ``` #### 自动化测试验证效果 创建单元测试案例模拟多次请求同一个资源接口的过程,观察日志输出次数的变化情况以确认是否达到了预期的效果——即除了第一次之外后续几次都应该命中缓存从而避免了重复计算开销。 ```java @Test void testFindBookById(){ assertEquals("book-1L", service.findBookById(1L)); assertEquals("book-1L", service.findBookById(1L)); // 应该从缓存读取 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值