本篇文章為大家展示了Springboot 如何使用本地緩存Caffeine,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
Caffeine是使用Java8對Guava緩存的重寫版本性能有很大提升
一 依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<!-- caffeine -->
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.7.0</version>
</dependency>二 配置緩存,單獨使用
只需要配置Bean就可以了,然后進行數據讀寫,注意這里提供了很多強大的自定義配置,可以查看文檔詳細配置
//定義緩存,可直接使用
@Bean
public LoadingCache expiryCache(){
LoadingCache<String, Object> loadingCache = Caffeine.newBuilder()
.initialCapacity(100)
.maximumSize(1000)
//緩存寫入/刪除監控
.writer(new CacheWriter<Object, Object>() {
@Override
public void write(Object key, Object value) { //此方法是同步阻塞的
System.out.println("--緩存寫入--:key=" + key + ", value=" + value);
}
@Override
public void delete(Object key, Object value, RemovalCause cause) { System.out.println("--緩存刪除--:key=" + key); }
})
.expireAfterAccess(1, TimeUnit.MINUTES) //過期時間
.build((String key)->"刷新的數據"); //cacheload實現類,刷新時候調用
loadingCache.put("name","侯征");
return loadingCache;
}測試使用:
@Autowired
private LoadingCache loadingCache;
@GetMapping("/get")
public Object getValue(String key){
return loadingCache.get(key);
}
@GetMapping("/add")
public void addValue(String value){
loadingCache.put(value,value);
}
@GetMapping("/delete")
public void deleteValue(String key){
loadingCache.invalidate(key);
loadingCache.invalidateAll();//清楚所有
}
@GetMapping("/refresh")
public void refreshValue(String key){
//刷新時會根據build方法中中指定的cacheload重新加載
loadingCache.refresh(key);
}三 配置CacheManager,和spring緩存注解一起使用
//配置CacheManager
@Bean(name = "caffeine")
public CacheManager cacheManagerWithCaffeine() {
CaffeineCacheManager cacheManager = new CaffeineCacheManager();
Caffeine caffeine = Caffeine.newBuilder()
//cache的初始容量值
.initialCapacity(100)
//maximumSize用來控制cache的最大緩存數量,maximumSize和maximumWeight(最大權重)不可以同時使用,
.maximumSize(1000)
//最后一次寫入或者訪問后過久過期
.expireAfterAccess(500, TimeUnit.SECONDS)
//創建或更新之后多久刷新,需要設置cacheLoader
.refreshAfterWrite(10, TimeUnit.SECONDS);
cacheManager.setCaffeine(caffeine);
cacheManager.setCacheLoader(cacheLoader);
cacheManager.setCacheNames(names);//根據名字可以創建多個cache,但是多個cache使用相同的策略
cacheManager.setAllowNullValues(false);//是否允許值為空
return cacheManager;
}配置 cacheload
/**
* 必須要指定這個Bean,refreshAfterWrite配置屬性才生效
*/
@Bean
public CacheLoader<Object, Object> cacheLoader() {
return new CacheLoader<Object, Object>() {
@Override
public Object load(Object key) throws Exception { return null;}
// 重寫這個方法將oldValue值返回回去,進而刷新緩存
@Override
public Object reload(Object key, Object oldValue) throws Exception {
System.out.println("--refresh--:"+key);
return oldValue;
}
};
}其他就是在service中配置spring的幾個緩存注解使用就行了,這里放一張截圖,這些注解用法,網上很多:[/code]

上述內容就是Springboot 如何使用本地緩存Caffeine,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。