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
    //配置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的幾個緩存注解使用就行了,這里放一張截圖,這些注解用法,網上很多:

 

 
       


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM