最近一个项目中遇到的问题,项目是基于SpringBoot,之前使用了默认的缓存(本地缓存),这次由于有新的需求不得不新增redis来存放新的业务数据,并且不希望变更之前的缓存使用方式,即默认还是使用本地缓存,新的业务使用redis做缓存,查了一下发现:
在Spring Boot中通过@EnableCaching注解自动化配置合适的缓存管理器(CacheManager),Spring Boot根据下面的顺序去侦测缓存提供者:
Generic
JCache (JSR-107)
EhCache 2.x
Hazelcast
Infinispan
Redis
Guava
Simple
默认配置的缓存管理器只能有一种实现,若同时配置了多种缓存管理器,排序靠前的会优先加载,之后的不会生效。若配置了Redis,默认的本地缓存Simple就不能使用了。除了按顺序侦测外,也可以通过配置属性spring.cache.type来强制指定。可以通过debug调试查看cacheManager对象的实例来判断当前使用了什么缓存。
解决办法:就是在application.properties 中配置属性使用Spring 自带的缓存管理器:spring.cache.type=Simple
这样使用的还是默认的缓存管理器,在新的业务的service层把数据放到redis中或从redis中读取,问题解决。