spring cache经常使用注解使用

一、@CacheConfig

主要用于配置该类中会用到的一些共用的缓存配置。示例:git

@CacheConfig(cacheNames = "users")
public interface UserService {。。。}

配置了该数据访问对象中返回的内容将存储于名为users的缓存对象中,咱们也能够不使用该注解,直接经过@Cacheable本身配置缓存集的名字来定义。github

二、@Cacheable

应用到读取数据的方法上,便可缓存的方法,如查找方法,先从缓存中读取,若是没有再调用相应方法获取数据,而后把数据添加到缓存中。spring

该注解主要有下面几个参数:数组

  • value、cacheNames:两个等同的参数(cacheNames为Spring 4新增,做为value的别名),用于指定缓存存储的集合名。因为Spring 4中新增了@CacheConfig,所以在Spring 3中本来必须有的value属性,也成为非必需项了
  • key:缓存对象存储在Map集合中的key值,非必需,缺省按照函数的全部参数组合做为key值,若本身配置需使用SpEL表达式,好比:@Cacheable(key = "#p0"):使用函数第一个参数做为缓存的key值,更多关于SpEL表达式的详细内容可参考官方文档
  • condition:缓存对象的条件,非必需,也需使用SpEL表达式,只有知足表达式条件的内容才会被缓存,好比:@Cacheable(key = "#p0", condition = "#p0.length() < 3"),表示只有当第一个参数的长度小于3的时候才会被缓存。
  • unless:另一个缓存条件参数,非必需,需使用SpEL表达式。它不一样于condition参数的地方在于它的判断时机,该条件是在函数被调用以后才作判断的,因此它能够经过对result进行判断。
  • keyGenerator:用于指定key生成器,非必需。若须要指定一个自定义的key生成器,咱们须要去实现org.springframework.cache.interceptor.KeyGenerator接口,并使用该参数来指定。须要注意的是:该参数与key是互斥的
  • cacheManager:用于指定使用哪一个缓存管理器,非必需。只有当有多个时才须要使用
  • cacheResolver:用于指定使用那个缓存解析器,非必需。需经过org.springframework.cache.interceptor.CacheResolver接口来实现本身的缓存解析器,并用该参数指定。

示例以下:缓存

@Cacheable(value = "user", key = "#id")
User selectUserById(final Integer id);

 三、@CachePut 

应用到写数据的方法上,如新增/修改方法,调用方法时会自动把相应的数据放入缓存,示例以下:springboot

@CachePut(value = "user", key = "#user.id")  
public User save(User user) {  
    users.add(user);  
    return user;  
}  

此时会以user.id作为缓存key,返回结果user作为值,测试过程当中发如今修改对象后只将缓存结果移除但key未移除,致使查询依然使用了缓存而结果为空(不知道啥状况)less

@CachePut的参数与@Cacheable相似函数

四、@CacheEvict 

应用到移除数据的方法上,如删除方法,调用方法时会从缓存中移除相应的数据,示例以下:测试

@CacheEvict(value = "user", key = "#id")
void delete(final Integer id);

除了同@Cacheable同样的参数以外,@CacheEvict还有下面两个参数:spa

  • allEntries:非必需,默认为false。当为true时,会移除全部数据
  • beforeInvocation:非必需,默认为false,会在调用方法以后移除数据。当为true时,会在调用方法以前移除数据。

五、@Caching

组合多个Cache注解使用。示例:

@Caching( 
    put = { 
        @CachePut(value = "user", key = "#user.id"), 
        @CachePut(value = "user", key = "#user.username"), 
        @CachePut(value = "user", key = "#user.age") 
   } 
} 

以上是将id-->user;username--->user;age--->user进行缓存。

六、缓存策略

若是缓存满了,从缓存中移除数据的策略,常见的有FIFO, LRU 、LFU

  • FIFO (First in First Out) 先进先出策略,即先放入缓存的数据先被移除
  • LRU (Least Recently Used) 最久未使用策略, 即便用时间距离如今最久的那个数据被移除
  • LFU (Least Frequently Used)  最少使用策略,即必定时间内使用次数(频率)最少的那个数据被移除
  • TTL(Time To Live)存活期,即从缓存中建立时间点开始至到期的一个时间段(无论在这个时间段内有没被访问过都将过时)
  • TTI (Time To Idle)空闲期,即一个数据多久没有被访问就从缓存中移除的时间。

七、附注

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

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

能够经过配置属性spring.cache.type来强制指定,即

spring.cache.type = xxx

另外可经过注入cacheManager来调试查看使用哪一种类型,进一步熟悉cache

@Autowired
private CacheManager cacheManager;

 

源码参照:Github

相关文章
相关标签/搜索