引入依赖
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>30.1.1-jre</version>
</dependency>
SpringBoot - InitializingBean的作用是什么?
InitializingBean的作用是Bean注入到Spring容器且初始化后,执行特定业务化的操作
如果采用实现InitializingBean接口的方式去执行特定业务化的操作,则需要重写afterPropertiesSet这仅有的一个方法。
@Slf4j
@Data
public class KieAccessor implements InitializingBean {
public LoadingCache<String, List<String>> getCache() {
return cache;
}
public void setCache(LoadingCache<String, List<String>> cache) {
this.cache = cache;
}
private LoadingCache<String, List<String>> cache = null;
@Override
public void afterPropertiesSet() throws Exception {
cache = CacheBuilder.newBuilder()
//设置并发级别为8,并发级别是指可以同时写缓存的线程数
.concurrencyLevel(8)
//设置缓存容器的初始容量为10
.initialCapacity(10)
//设置缓存最大容量为100,超过100之后就会按照LRU最近虽少使用算法来移除缓存项
.maximumSize(100)
//是否需要统计缓存情况,该操作消耗一定的性能,生产环境应该去除
// .recordStats()
//设置写缓存后n秒钟过期
.expireAfterWrite(48, TimeUnit.HOURS)
//设置读写缓存后n秒钟过期,实际很少用到,类似于expireAfterWrite
//.expireAfterAccess(17, TimeUnit.SECONDS)
//只阻塞当前数据加载线程,其他线程返回旧值
//.refreshAfterWrite(13, TimeUnit.SECONDS)
// //设置缓存的移除通知
//GuavaCache 并不保证在过期时间到了之后立刻删除该 <Key,Value>,如果你此时去访问了这个 Key,
//它会检测是不是已经过期,过期就删除它,所以过期时间到了之后你去访问这个 Key 会显示这个 Key 已经被删除,
//但是如果你不做任何操作,那么在 过期时间到了之后也许这个<Key,Value> 还在内存中。
.removalListener(new RemovalListener<String, List<String>>() {
public void onRemoval(RemovalNotification<String, List<String>> notification) {
LOGGER.info("[" + notification.getKey() + ":" + notification.getValue().toString() + "] is removed!");
}
})
//build方法中可以指定CacheLoader,在缓存不存在时通过CacheLoader的实现自动加载缓存
.build(new MyCacheLoader());
}
/**
* 随机缓存加载,实际使用时应实现业务的缓存加载逻辑,例如从数据库获取数据
* 不存在,会加载到缓存当中,若是过期失效,再次访问时会先删除(如上的removalListener),再加载数据
*/
public static class MyCacheLoader extends CacheLoader<String, List<String>> {
@Override
public List<String> load(String key) throws Exception {
List<String> asList ;
if(key.equals("1")){
asList=Arrays.asList("1", "2", "3");
}else {
asList=null;
}
return asList;
}
}
}