创建了自定义的keyGenerator之后。每次要使用的话经常需要CacheConfig。为了省去这个步骤,直接设置自定义的keyGenerator为默认。设置之后呢,就不需要设置CacheConfig。只需要在方法上加上@Cacheable就可以了。
改动呢就是2点,一个是要继承这个类。还有呢,就是加上@Override就可以了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | /** * 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; } } |