Spring Boot 增加缓存功能

2020/10/21 posted in  Spring Java
spring.jpa.properties.hibernate.show_sql=true,开启hibernate对sql语句的打印

单元测试中,用userRepository 查询两次相同内容。


运行一下,会看到在控制台打出了两条sql,说明是查了两次库。

增加缓存:
pom中添加依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

SpringBoot主类中添加注解 @EnableCaching
UserRepository 类添加注解@CacheConfig(cacheNames = "users")
findByName方法添加注解@Cacheable

org.springframework.data.redis.serializer.SerializationException:?

缓存对象需要实现序列化接口.UserDO implements Serializable

在次运行就会出现

可以看到,第二次请求的时候就没有打印出sql语句。

注解:

  • @CacheConfig:
    主要配置该类中会用到的一些公用的缓存配置。
    cacheNames 配置了数据访问对象中返回的内容将存储于名为users的数组中。

  • @Cacheable:
    配置了findByName的函数返回值将会被加入到缓存。同时在查询时,会先查询缓存,若不存在才会查询数据库。

  • cacheNamesvalue:用于指定缓存存储的集合名。两个参数等效。

  • key:缓存对象存储在Map集合中的key值,非必需,缺省按照函数的所有参数组合作为key值,若自己配置需使用SpEL表达式,比如:@Cacheable(key = "#p0"):使用函数第一个参数作为缓存的key值,更多关于SpEL表达式的详细内容可参考官方文档

  • condition:缓存对象的条件,非必需,也需使用SpEL表达式,只有满足表达式条件的内容才会被缓存,比如:@Cacheable(key = "#p0", condition = "#p0.length() < 3"),表示只有当第一个参数的长度小于3的时候才会被缓存,若做此配置上面的AAA用户就不会被缓存,读者可自行实验尝试。

  • unless:另外一个缓存条件参数,非必需,需使用SpEL表达式。它不同于condition参数的地方在于它的判断时机,该条件是在函数被调用之后才做判断的,所以它可以通过对result进行判断。

  • keyGenerator:用于指定key生成器,非必需。若需要指定一个自定义的key生成器,我们需要去实现org.springframework.cache.interceptor.KeyGenerator接口,并使用该参数来指定。需要注意的是:该参数与key是互斥的

  • cacheManager:用于指定使用哪个缓存管理器,非必需。只有当有多个时才需要使用

  • cacheResolver:用于指定使用那个缓存解析器,非必需。需通过org.springframework.cache.interceptor.CacheResolver接口来实现自己的缓存解析器,并用该参数指定。

CacheManager

在Spring Boot中通过@EnableCaching注解自动化配置合适的缓存管理器(CacheManager),Spring Boot根据下面的顺序去侦测缓存提供者:

  • Generic
  • JCache (JSR-107)
  • EhCache 2.x
  • Hazelcast
  • Infinispan
  • Redis
  • Guava
  • Simple

可以通过配置属性spring.cache.type来强制指定