Spring @Cacheable缓存注解用法说明

注解Cacheable 是 Spring 框架中用于缓存数据的方法或类的注解。通过使用这个注解,你可以避免重复计算和重复获取数据,从而提高应用程序的性能。

基本用法

  • 引入依赖

确保在你的项目中引入了 Spring Cache 相关的依赖。如果你使用的是 Spring Boot,可以在 pom.xml 中添加以下依赖:

html 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>
  • 启用缓存

在主类或配置类上使用 @EnableCaching 注解来启用缓存功能。

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

在需要缓存的方法上使用 @Cacheable 注解。

bash 复制代码
@Service
public class UserService {

    @Cacheable("lizz:users")
    public User getUserById(Long id) {
        // 模拟一个耗时的数据库查询
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return new User(id, "John Doe");
    }
}
  • 配置缓存

Spring 提供了多种缓存实现,包括内存缓存(如 ConcurrentMapCache)、第三方缓存(如 EhCache、Caffeine、Redis 等)。可以在配置文件(如 application.propertiesapplication.yml)中进行配置。

  • 使用 ConcurrentMapCache本地缓存
bash 复制代码
spring:
  cache:
    type: simple
  • 使用 Redis 作为缓存
bash 复制代码
spring:
  cache:
    type: redis
  redis:
    host: 172.1.1.11
    port: 6379

高级用法

  • 缓存条件: condition

使用 condition 属性指定缓存条件,只换成id大于10的数据缓存

java 复制代码
@Cacheable(value = "lizz:users", condition = "#id > 10")
public User getUserById(Long id) {
    // ...
}
  • 自定义缓存键

使用 key 属性自定义缓存键。

java 复制代码
@Cacheable(value = "users", key = "#root.methodName + #id")
public User getUserById(Long id) {
    // ...
}
  • **同步更新:**sync

sync=true时,如果多个线程同时访问缓存中没有的数据,只有一个线程会执行方法以加载数据,其他线程会等待加载完成并获取相同的结果。这可以防止缓存穿透(即多个线程同时访问缓存时都绕过缓存直接访问底层存储)。

java 复制代码
@Cacheable(value = "users", sync = true)
public User getUserById(Long id) {
    // ...
}

缓存失效:@CacheEvict

  • allEntries=true:清除所有缓存数据
java 复制代码
@CacheEvict(value = "lizz:users", allEntries = true)
public void clearCache() {
    // //清除全部缓存相关的其他业务操作
}
  • key = "#id" :清除缓存集合中指定key的数据
java 复制代码
@CacheEvict(value = "lizz:users", key = "#id")
public void delUser(Long id) {
    //清除id缓存相关的其他业务操作
}
  • 缓存同步: @CachePut

使用 @CachePut 注解更新缓存。

java 复制代码
@CachePut(value = "lizz:users", key = "#user.id")
public User updateUser(User user) {
    // 更新用户的逻辑
    return user;
}

结合缓存组件

  • 引入caffeine
html 复制代码
        <!--快速本地缓存-->
        <dependency>
            <groupId>com.github.ben-manes.caffeine</groupId>
            <artifactId>caffeine</artifactId>
        </dependency>
  • 使用caffeine作为springcache管理
java 复制代码
@EnableCaching
@Configuration
public class CaffeineCacheConfig {

    @Bean
    public CacheManager cacheManager() {
        CaffeineCacheManager cacheManager = new CaffeineCacheManager("ta:region");
        cacheManager.setCaffeine(caffeineCacheBuilder());
        return cacheManager;
    }

    Caffeine<Object, Object> caffeineCacheBuilder() {
        return Caffeine.newBuilder()
                .expireAfterWrite(1, TimeUnit.MINUTES)
                .maximumSize(100);
    }
}
相关推荐
ps酷教程2 小时前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云2 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
_日拱一卒3 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠3 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨4 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝4 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区5 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
金銀銅鐵5 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
云烟成雨TD5 小时前
Spring AI Alibaba 1.x 系列【63】AI Agent 长期记忆
java·人工智能·spring
憧憬成为java架构高手的小白5 小时前
苍穹外卖--day09
java·spring boot·百度