当前位置: 首页 > 工具软件 > Caffeine > 使用案例 >

spring集成caffeine缓存

闻人修平
2023-12-01

1,官网wiki


caffeine官网链接

2,api

api help

3,引入pom依赖,注意caffeine版本,如果springboot版本太低引入高版本caffeine会报错

倾向于只使用caffeine提供的pom,不用springboot集成的 cache start,如下

        <!--caffeine本地缓存-->
        <dependency>
            <groupId>com.github.ben-manes.caffeine</groupId>
            <artifactId>caffeine</artifactId>
            <version>2.9.3</version>
        </dependency>

4,Caffeine提供了四种缓存添加策略:手动加载,自动加载,手动异步加载和自动异步加载。

5,spring配置bean,这里使用手动加载策略,配置的bean中可自定义线程池

@Configuration
public class CacheConfig {

    /**
     * 默认缓存配置,key为string,value为object,如果value想自定义为目标对象,可新建一个@Bean
     *
     * @return
     */
    @Bean(name = "caffeineCache")
    public Cache<String, Object> caffeineCache() {
        return Caffeine.newBuilder()
                // 设置最后一次写入或访问后经过固定时间过期
                .expireAfterWrite(60 * 10, TimeUnit.SECONDS)
                // 缓存的最大条数
                .maximumSize(1000)
                .build();
    }

    @Bean(name = "caffeineCacheString")
    public Cache<String, String> caffeineCacheString() {
        return Caffeine.newBuilder()
                // 设置最后一次写入或访问后经过固定时间过期
                .expireAfterWrite(60 * 10, TimeUnit.SECONDS)
                // 缓存的最大条数
                .maximumSize(1000)
                .build();
    }
}

6,缓存模板类,省略

7,使用

CacheTemplate<List<MenuInfo>> cacheTemplate = new CacheTemplate() {
            @Override
            protected List<MenuInfo> getDB() {
                return menuInfoMapper.getTreeList();
            }
        };
List<MenuInfo> menuList = cacheTemplate.getCaffeine("test", caffeineCache);

 类似资料: