当我们调用一个方法时会把该方法的参数和返回结果最为一个键值对存放在缓存中,等下次利用同样的参数来调用该方法时将不会再执行,而是直接从缓存中获取结果进行返回。
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId></dependency>#指定缓存类型spring:cache:type: redis#启动类开启缓存注解@EnableCaching
#缓存配置 修改序列化器、缓存过期时间、缓存key生成规则@Configurationpublic class CacheConfig {@Beanpublic KeyGenerator DefaultKeyGenerator(){return new KeyGenerator() {@Overridepublic Object generate(Object o, Method method, Object... objects) {return o.getClass().getSimpleName() + "_"+ method.getName() + "_"+ StringUtils.arrayToDelimitedString(objects, "_");}};}@Bean@Primarypublic RedisCacheManager cacheManager1Hour(RedisConnectionFactory connectionFactory) {RedisCacheConfiguration config =instanceConfig(3600L);returnRedisCacheManager.builder(connectionFactory).cacheDefaults(config).transactionAware().build();}@Beanpublic RedisCacheManager cacheManager1Day(RedisConnectionFactory connectionFactory) {RedisCacheConfiguration config =instanceConfig(3600 * 24L);returnRedisCacheManager.builder(connectionFactory).cacheDefaults(config).transactionAware().build();}private RedisCacheConfiguration instanceConfig(Long ttl) {Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer =new Jackson2JsonRedisSerializer<>(Object.class);ObjectMapper objectMapper = new ObjectMapper();objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);objectMapper.registerModule(new JavaTimeModule());// 去掉各种@JsonSerialize注解的解析objectMapper.configure(MapperFeature.USE_ANNOTATIONS, false);// 只针对⾮空的值进⾏序列化objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);// 将类型序列化到属性json字符串中objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance,ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.PROPERTY);jackson2JsonRedisSerializer.setObjectMapper(objectMapper);returnRedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofSeconds(ttl)).disableCachingNullValues().serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer));}}
常用注解
Cacheable
缓存标注对象的返回结果,标注在⽅法上缓存该⽅法的返回值,标注在类上缓存该类所有的⽅法返回值。
value 缓存名称,可以有多个key 缓存的key规则,可以⽤springEL表达式,默认是⽅法参数组合;cacheManager缓存管理器;condition 缓存条件,使⽤springEL编写,返回true才缓存
@Cacheable(value = "Article",keyGenerator = "DefaultKeyGenerator",cacheManager = "cacheManager1Day")
CachePut
用于更新操作时,同时把缓存中的数据更新;注意key值要和缓存里面的key保持一致
CacheEvict
用于删除操作时,同时把缓存中的数据删除
参数:
- beforeInvocation = false
- 缓存的清除是否在⽅法之前执⾏ ,默认代表缓存清除 操作是在⽅法执⾏之后执⾏; 如果出现异常缓存就不会清除
- beforeInvocation = true
- 代表清除缓存操作是在⽅法运⾏之前执⾏,⽆论⽅法是否出现异常,缓存都清除
Caching
允许在同⼀⽅法上使⽤多个嵌套的@Cacheable、@CachePut和@CacheEvict注释;可以同时生效
@Caching(cacheable = {@Cacheable(value ="product",keyGenerator = "xdclassKeyGenerator")},put = {@CachePut(value ="product",key = "#id"),@CachePut(value ="product",key = "'stock:'+#id")})
