spring boot集成caffeine本地缓存

呃.................................

....................废话不多说,直接干代码

1、先添加pom依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>

        <dependency>
            <groupId>com.github.ben-manes.caffeine</groupId>
            <artifactId>caffeine</artifactId>
        </dependency>
spring-boot版本是:2.4.2

2、启动类添加开启缓存注解

@EnableCaching

3、添加缓存配置文件

@Configuration
public class CacheConfig {

    @Value("${cache.time}")
    private String cacheTime;


    @Bean("caffeineCacheManager")
    public CacheManager cacheManager() {
        CaffeineCacheManager caffeineCacheManager = new CaffeineCacheManager();
        caffeineCacheManager.setCaffeine(getCaffeine());
        caffeineCacheManager.setCacheLoader(cacheLoader());
        //是否允许值为空
        caffeineCacheManager.setAllowNullValues(false);
        return caffeineCacheManager;
    }


    @Bean
    public CacheLoader<Object, Object> cacheLoader() {
        return new CacheLoader<Object, Object>() {
            @Override
            public @Nullable
            Object load(@NonNull Object key) throws Exception {
                // 这里我们就可以从数据库或者其他地方查询最新的数据
                return null;
            }

            @Override
            public @Nullable
            Object reload(@NonNull Object key, @NonNull Object oldValue) throws Exception {
                System.out.println("--refresh--:" + key);
                return oldValue;
            }
        };

    }

    @Bean
    public LoadingCache getCache() {
        LoadingCache build = getCaffeine().build(cacheLoader());
        return build;
    }


    @Bean
    public Caffeine getCaffeine() {
        Integer time = Integer.parseInt(StringUtils.isEmpty(cacheTime) ? "1440" : cacheTime);
        Caffeine caffeine = Caffeine.newBuilder()
                //设置过期时间。最后一次写入或访问后过多久过期。
                .expireAfterAccess(time * 60, TimeUnit.SECONDS)
                //cache的初始容量值
                .initialCapacity(100)
                //maximumSize用来控制cache的最大缓存数量,maximumSize和maximumWeight(最大权重)不可以同时使用,
                .maximumSize(1000)
                //弱引用
                //  .weakKeys()
                //  .weakValues()
                //创建或更新之后多久刷新,需要设置cacheLoader
                //  .refreshAfterWrite(10, TimeUnit.SECONDS)
                //缓存写入/删除 监控
                .writer(new CacheWriter<Object, Object>() {

                    @Override
                    public void write(@NonNull Object key, @NonNull Object value) {
                        System.out.println("缓存写入: key= " + key + ";value=" + value);
                    }

                    @Override
                    public void delete(@NonNull Object key, @Nullable Object value, @NonNull RemovalCause cause) {
                        System.out.println("缓存删除: key= " + key + ";value=" + value);

                    }
                })
                .recordStats();


        return caffeine;
    }
}

我这里时间是用的读取的外部配置文件,方便修改。

缓存更新策略

expireAfterAccess(long, TimeUnit):在最后一次访问或者写入后开始计时,在指定的时间后过期。假如一直有请求访问该key,那么这个缓存将一直不会过期。
expireAfterWrite(long, TimeUnit)::在最后一次写入缓存后开始计时,在指定的时间后过期。
expireAfter(Expiry)::自定义策略,过期时间由Expiry实现独自计算。

4、使用

在需要的方法上面添加注解:@Cacheable、@CacheEvict、@CachePut

@Cacheable(cacheNames = "userInfo", key = "#param.uid+'_'+#param.uname")
    public List<UserInfo> getUserInfo(UserParam param) {
    // 查询数据信息
}

5、完

本文内容简单,后面有时间再丰富。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot Caffeine 是一个用于集成 Spring BootCaffeine 缓存库的插件。Caffeine 是一个高性能的 Java 缓存库,它提供了内存缓存的功能,可以减少对数据库或其他外部资源的访问次数,从而提高应用程序的性能。 要在 Spring Boot 中使用 Caffeine,首先需要添加以下 Maven 依赖项: ```xml <dependency> <groupId>com.github.ben-manes.caffeine</groupId> <artifactId>caffeine</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId> </dependency> ``` 接下来,在你的 Spring Boot 应用程序的配置类上添加 `@EnableCaching` 注解,以启用缓存功能。然后,在需要缓存的方法上添加 `@Cacheable` 注解,指定缓存的名称和缓存的键。 例如,假设你有一个 UserService 类,其中有一个需要进行缓存的方法 getUserById: ```java @Service public class UserService { @Cacheable("users") public User getUserById(Long id) { // 从数据库或其他外部资源获取用户信息 return userRepository.findById(id); } } ``` 在上面的例子中,使用了 `@Cacheable("users")` 注解来指定缓存的名称为 "users",并且根据传入的 id 参数进行缓存。当该方法被调用时,如果缓存中已经存在相应的键值对,则直接从缓存中获取结果,否则会执行方法体内的代码,并将结果存入缓存中。 另外,你还可以使用 `@CacheEvict` 注解来清除缓存中的数据,例如: ```java @CacheEvict("users") public void deleteUserById(Long id) { // 删除用户操作 } ``` 上述代码中的 `@CacheEvict("users")` 注解会在 deleteUserById 方法执行后清除名为 "users" 的缓存。 通过以上的配置和注解,你就可以在 Spring Boot 应用程序中使用 Caffeine 缓存来提高性能了。当然,还有其他更多的配置选项和注解可以使用,你可以根据自己的需求进行调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值