创建了自定义的keyGenerator之后。每次要使用的话经常需要CacheConfig。为了省去这个步骤,直接设置自定义的keyGenerator为默认。设置之后呢,就不需要设置CacheConfig。只需要在方法上加上@Cacheable就可以了。
改动呢就是2点,一个是要继承这个类。还有呢,就是加上@Override就可以了。
/**
* Created by 张某松 on 2020/6/10.
*/
@Configuration
@EnableCaching
public class CacheConfig extends CachingConfigurerSupport{
org.slf4j.Logger logger= org.slf4j.LoggerFactory.getLogger(getClass());
@Resource
private RedisConnectionFactory redisConnectionFactory;//显示红色报错不用管。
@Bean
@Primary
@Override //继承上面这个类,并且加上这个之后才能把它设置为默认的。
public KeyGenerator keyGenerator() {
return new KeyGenerator() {
@Override
public Object generate(Object target, Method method, Object... params) {
String re= String.format("%s::%s(%s)",target.getClass().getName(),method.getName(),
CollectionUtils.arrayToList(params));//Arrays.asList(params)
logger.debug("缓存生成的key:{}。",re);
return re;
}
};
}
@Bean
@Primary
@Override
public CacheManager cacheManager() {
super.cacheManager();
RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofHours(1)); // 设置缓存有效期一小时
// .serializeValuesWith(serializationPair());
//genericJackson2JsonRedisSerializer()取代RedisSerializer.json()解决Could not read JSON: Cannot construct instance of `java.time.LocalTime` (no Creators, like default construct, exist)
// RedisCacheManager redisCacheManager = RedisCacheManager
// .builder(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory))
// .cacheDefaults(redisCacheConfiguration).build();
Map<String, RedisCacheConfiguration> initialCacheConfigurations=new HashMap<>();
initialCacheConfigurations.put("sixHoursCache",RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofHours(6)));
// 这一行代码会导致空置针,但是上面设置这一项,却没有控制真错误
// .serializeValuesWith(serializationPair()));;
// initialCacheConfigurations.put("fiveMinutesCache",RedisCacheConfiguration.defaultCacheConfig()
// .entryTtl(Duration.ofMinutes(5)));
// .serializeValuesWith(serializationPair()));;
initialCacheConfigurations.put("minuteCache",RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofMinutes(1)));
// .serializeValuesWith(serializationPair()));
RedisCacheManager redisCacheManager=new RedisCacheManager(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory),
redisCacheConfiguration,
initialCacheConfigurations,
true);
return redisCacheManager;
}
}