概述

  • 将方法的运行结果进行缓存;以后再要相同的数据,直接从缓存中获取,不用调用方法;
  • CacheManager管理多个Cache组件的,对缓存的真正CRUD操作在Cache组件中,每一个缓存组件有自己唯一的名字;
    Screenshot_20200323_164838.jpg
  • 缓存的注释写在service类的方法上

1. @Cacheable的使用

  • 运行流程
    @Cacheable
    1、方法运行之前,先去查询Cache(缓存组件),按照cacheNames指定的名字获取;
    (CacheManager先获取相应的缓存),第一次获取缓存如果没有Cache组件会自动创建。
    2、去Cache中查找缓存的内容,使用一个key,默认就是方法的参数;
    key是按照某种策略生成的;默认是使用keyGenerator生成的,默认使用SimpleKeyGenerator生成key;
    SimpleKeyGenerator生成key的默认策略;
    如果没有参数;key=new SimpleKey();
    如果有一个参数:key=参数的值
    如果有多个参数:key=new SimpleKey(params);
    3、没有查到缓存就调用目标方法;
    4、将目标方法返回的结果,放进缓存中

  • 核心
    1)、使用CacheManager【ConcurrentMapCacheManager】按照名字得到Cache【ConcurrentMapCache】组件
    2)、key使用keyGenerator生成的,默认是SimpleKeyGenerator

  • 几个属性
    cacheNames/value:指定缓存组件的名字;将方法的返回结果放在哪个缓存中,是数组的方式,可以指定多个缓存;

    key:缓存数据使用的key;可以用它来指定。默认是使用方法参数的值 1-方法的返回值
    编写SpEL; #i d;参数id的值 #a0 #p0 #root.args[0]
    getEmp[2]
    Screenshot_20200323_164918.jpg

    keyGenerator:key的生成器;可以自己指定key的生成器的组件id
    key/keyGenerator:二选一使用;

    cacheManager:指定缓存管理器;或者cacheResolver指定获取解析器

    condition:指定符合条件的情况下才缓存
    unless:否定缓存
    sync:是否使用异步模式

  • 代码实现

@Cacheable(cacheNames = {"emp"}, condition = "#id==1")
public Employee getEmp(Integer id) {
    System.out.println("查询" + id + "号员工");
    Employee employee = employeeMapper.getEmpById(id);
    return employee;
}

2. @CachePut的使用

  • 既调用方法,又更新缓存数据;同步更新缓存
  • 先调用目标方法,然后将目标方法的结果缓存起来
  • 可以同步更新缓存的前提是key相同
    • key = "#employee.id":使用传入的参数的员工id;
    • key = "#result.id":使用返回后的id
  • 代码实现
@CachePut(value = "emp",key = "#employee.id")
public Employee updateEmp(Employee employee){
    System.out.println("updateEmp:"+employee);
    employeeMapper.updateEmp(employee);
    return employee;
}

3. @CacheEvict的使用

  • 概述:缓存清除
    key:指定要清除的数据

    allEntries = true:指定清除这个缓存中所有的数据

    缓存的清除是否在方法之前执行
    beforeInvocation = false
    默认代表缓存清除操作是在方法执行之后执行;如果出现异常缓存就不会清除
    beforeInvocation = true
    代表清除缓存操作是在方法运行之前执行,无论方法是否出现异常,缓存都清除

  • 代码实现:

@CacheEvict(value = "emp", key = "#id")
public int deleteEmp(Integer id) {
    System.out.println("deleteEmp" + id);
    return employeeMapper.deleteEmpById(id);
}

4. @Caching的使用

  • 定义复杂的缓存规则
  • 代码实现:
@Caching(
        cacheable = {
                @Cacheable(value="emp",key = "#lastName")
        },
        put = {
                @CachePut(value="emp",key = "#result.id"),
                @CachePut(value="emp",key = "#result.email")
        }
)
public Employee getEmpByLastName(String lastName) {
    return employeeMapper.getEmpByLastName(lastName);
}

@CacheConfig

  • 抽取缓存的公共配置
  • 注释在service类上
  • @CacheConfig(cacheNames = "emp")

hhhhh