springboot整合jetcache
一、添加pom依赖
<dependency>
<groupId>com.alicp.jetcache</groupId>
<artifactId>jetcache-starter-redis</artifactId>
<version>2.5.11</version>
</dependency>
二、yml配置文件
jetcache:
statIntervalMinutes: 15 //统一间隔
areaInCacheName: false //设置不把areaName作为key的前置
hiddenPackages: com.alibaba //如果@Cached和@CreateCache的name是自动生成的,会默认的将包
//名和方法名作为前缀,为了不让name太长,该设置时将制定的包名截掉
local://本地缓存
default:
type: linkedhashmap //本地缓存类型
limit: 100
keyConvertor: fastjson //key的序列化转化的协议
expireAfterWriteInMillis: 100000 //缓存的时间,全局 默认值
remote://远程缓存
default:
type: redis //缓存数据库类型
keyConvertor: fastjson
valueEncoder: java
valueDecoder: java
poolConfig:
minIdle: 5
maxIdle: 20
maxTotal: 50
host: 127.0.0.1
port: 6379
三、开启注解缓存
@SpringBootApplication
@EnableMethodCache(basePackages = "com.test")//开启方法缓存注解
@EnableCreateCacheAnnotation//开启属性注解
public class JetcacheSpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(JetcacheSpringbootApplication.class);
}
}
四、注解说明
- @CreateCache:用于字段上的注解,创建缓存。根据参数,创建一个name的缓存,可以全局显式使用这个缓存参数对象
- @Cached:为一个方法返回值加入缓存
- @CacheUpdate:更新缓存
- @CacheInvalidate:删除缓存
- @CacheRefresh:刷新缓存
@CacheUpdate和@CacheInvalidate的name和area属性必须和@Cached相同,name属性还会用做cache的key前缀。
@CreateCache常用属性
属性 | 默认值 | 说明 |
---|---|---|
name | 未定义 | 指定缓存的名称,不是必须的,如果没有指定,会使用类名+方法名。name会被用于远程缓存的key前缀。另外在统计中,一个简短有意义的名字会提高可读性。如果两个@CreateCache 的name 和area 相同,它们会指向同一个Cache 实例 |
expire | 未定义 | 该Cache实例的默认超时时间定义,注解上没有定义的时候会使用全局配置,如果此时全局配置也没有定义,则取无穷大 |
timeUnit | TimeUnit.SECONDS | 指定expire的单位 |
cacheType | CacheType.REMOTE | 缓存的类型,包括CacheType.REMOTE、CacheType.LOCAL、CacheType.BOTH。如果定义为BOTH,会使用LOCAL和REMOTE组合成两级缓存 |
@Cached常用属性
属性 | 默认值 | 说明 |
---|---|---|
name | 未定义 | 指定缓存的名称,不是必须的,如果没有指定,会使用类名+方法名。name会被用于远程缓存的key前缀。另外在统计中,一个简短有意义的名字会提高可读性。如果两个@CreateCache 的name 和area 相同,它们会指向同一个Cache 实例 |
key | 未定义 | 使用SpEL指定key,如果没有指定会根据所有参数自动生成。 |
expire | 未定义 | 该Cache实例的默认超时时间定义,注解上没有定义的时候会使用全局配置,如果此时全局配置也没有定义,则取无穷大 |
timeUnit | TimeUnit.SECONDS | 指定expire的单位 |
cacheType | CacheType.REMOTE | 缓存的类型,包括CacheType.REMOTE、CacheType.LOCAL、CacheType.BOTH。如果定义为BOTH,会使用LOCAL和REMOTE组合成两级缓存 |
@CacheUpdate注解说明
属性 | 默认值 | 说明 |
---|---|---|
name | 未定义 | 指定缓存的名称,不是必须的,如果没有指定,会使用类名+方法名。name会被用于远程缓存的key前缀。另外在统计中,一个简短有意义的名字会提高可读性。如果两个@CreateCache 的name 和area 相同,它们会指向同一个Cache 实例 |
key | 未定义 | 使用SpEL指定key,如果没有指定会根据所有参数自动生成。 |
value | 未定义 | 使用SpEL指定value |
condition | TimeUnit.SECONDS | 使用SpEL指定条件,如果表达式返回true才执行更新位 |
@CacheInvalidate注解说明:
属性 | 默认值 | 说明 |
---|---|---|
name | 未定义 | 指定缓存的名称,不是必须的,如果没有指定,会使用类名+方法名。name会被用于远程缓存的key前缀。另外在统计中,一个简短有意义的名字会提高可读性。如果两个@CreateCache 的name 和area 相同,它们会指向同一个Cache 实例 |
key | 未定义 | 使用SpEL指定key,如果没有指定会根据所有参数自动生成。 |
condition | 未定义 | 使用SpEL指定条件,如果表达式返回true才执行删除 |
@CacheRefresh注解说明
属性 | 默认值 | 说明 |
---|---|---|
refresh | 未定义 | 刷新间隔 |
timeUnit | TimeUnit.SECONDS | 时间单位 |
stopRefreshAfterLastAccess | 未定义 | 指定该key多长时间没有访问就停止刷新,如果不指定会一直刷新 |
四、属性缓存
@CreateCache(name = "/stringCache", expire = 3600, cacheType = CacheType.REMOTE)
private Cache<Integer, String> stringCache;
@PostMapping("/setValue")
public String setValue(@RequestBody @Validated SetValue setValue) {
stringCache.put(setValue.getKey(), setValue.getValue());
return "加入缓存";
}
@GetMapping("/getValue")
public String getValue(String key) {
return stringCache.get(key);
}
五、方法缓存
@Cached(name = "stringCache1_", key = "#key", expire = 100)
@GetMapping("/getStrByKey")
@CacheRefresh(refresh = 60)
public String getStrByKey(Integer key) {
return stringCacheService.getStr(key);
}
@CacheUpdate(name = "stringCache1_", key = "#key", value = "#value")
@GetMapping("/updateStrCache")
public void updateStr(String key,String value){
System.out.println("更新缓存成功");
}
@CacheInvalidate(name = "stringCache1_",key = "#key")
@RequestMapping("/deleteStrCache")
public void deleteCache(String key){
System.out.println("删除缓存,key:"+key);
}