spring的CacheManager

org.springframework.cache.CacheManager是Spring框架中的一个接口,用于管理应用程序中的缓存。它提供了一种抽象的方式来访问缓存,使得应用程序可以使用不同的缓存实现(如内存、Redis等)而不需要修改代码。

在Spring Boot项目中,可以通过在配置类中添加@EnableCaching注解来启用缓存功能,并使用@Bean注解创建CacheManager实例。例如:

复制代码
@Configuration
@EnableCaching
public class CacheConfig {

    @Bean
    public CacheManager cacheManager() {
        return new ConcurrentMapCacheManager("myCache");
    }
}

上述代码中,我们使用ConcurrentMapCacheManager创建了一个名为"myCache"的缓存实例,并将其注入到Spring容器中。

在使用缓存的地方,可以通过@Cacheable注解来标记需要缓存的方法,并指定缓存名称。例如:

复制代码
@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    @Cacheable("myCache")
    public User getUserById(Long id) {
        return userRepository.findById(id).orElse(null);
    }
}

上述代码中,我们通过@Cacheable注解将getUserById方法标记为需要缓存的方法,并指定缓存名称为"myCache"。当该方法被调用时,如果缓存中已经存在对应的结果,则直接返回缓存中的数据,否则执行方法体并将结果存入缓存中。

需要注意的是,@Cacheable注解默认使用方法的参数作为缓存的key,因此在使用时需要保证参数的唯一性。如果需要使用其他方式生成缓存key,可以使用@Cacheable注解的key属性来指定。例如:

复制代码
@Cacheable(value = "myCache", key = "#user.id")
public User saveUser(User user) {
    return userRepository.save(user);
}

上述代码中,我们使用了用户对象的id属性作为缓存key,以保证缓存的唯一性。

相关推荐
砍材农夫1 分钟前
物联网 基于netty核心实战-心跳保活机制
java·后端·物联网·struts·servlet·netty
小江的记录本7 分钟前
【JVM虚拟机】垃圾回收GC:垃圾判定算法:引用计数法、可达性分析算法(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·spring·面试
彦楠10 分钟前
指定Tomcat运行的JDK地址
java·开发语言·tomcat
Byron__14 分钟前
JVM垃圾回收与调优核心面试笔记(引用计数/GC算法/CMS/G1/参数调优)
java·jvm·笔记·面试
XiYang-DING15 分钟前
【Spring】 SpringBoot 配置文件
java·spring boot·spring
那小子、真烦24 分钟前
Hermes Agent Chat 方法分析
java·开发语言
01_ice40 分钟前
Java抽象类和接口
java·开发语言
小马爱打代码1 小时前
Spring源码 第七篇:Spring Boot 自动配置原理深度拆解
java·spring boot·spring
日取其半万世不竭1 小时前
给 Docker 容器设置 CPU 和内存限制,避免单个服务拖垮整机
java·docker·容器
铁皮哥1 小时前
【agent 开发】Claude Code 的 Skill 是怎么被加载的?从 name/description 到 SKILL.md 再到资源文件
java·服务器·数据库·python·gitee·github·软件工程