spring boot caffeine cache 缓存学习

12 篇文章 0 订阅
4 篇文章 0 订阅

spring boot caffeine cache 缓存学习

  1. 自定义key
  2. 自定义全局key过期时间,缓存个数
  3. 针对单个key自定义过期时间,缓存个数

配置

  • yml配置:
    • 优点:简单
    • 缺点:无法针对每个cache配置不同的参数,比如过期时间、最大个数
  • java配置
    • 优点:可以针对每个cache配置不同的参数,比如过期时间、最大个数
    • 缺点:java代码

引入依赖

    <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>

自定义key

    @Override
    @Cacheable(value = "user", key = "'user'.concat(#id.toString())")
    public User findUserById(Long id) {
        log.info("findUserById query from db, id: {}", id);
        return userMap.get(id);
    }
    @Override
    @CachePut(value = "user", key = "'user'.concat(#user.id.toString())")
    public User update(User user) {
        log.info("update db, user: {}", user.toString());
        userMap.put(user.getId(), user);
        return user;
    }
    @Override
    @CacheEvict(value = "user", key = "'user'.concat(#id.toString())")
    public void remove(Long id) {
        log.info("remove from db, id: {}", id);
        userMap.remove(id);
    }

java配置

package com.km.config;

import com.github.benmanes.caffeine.cache.Caffeine;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.caffeine.CaffeineCache;
import org.springframework.cache.support.SimpleCacheManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.ArrayList;
import java.util.concurrent.TimeUnit;

/**
 * <p>java方式:caffeine缓存配置</p>
 * Created by zhezhiyong@163.com on 2017/9/22.
 */
@Configuration
@EnableCaching
public class CacheConfig {

    private static final int DEFAULT_MAXSIZE = 1000;
    private static final int DEFAULT_TTL = 3600;

    /**
     * 定义cache名称、超时时长秒、最大个数
     * 每个cache缺省3600秒过期,最大个数1000
     */
    public enum Caches {
        user(60, 2),
        info(5),
        role;

        Caches() {
        }

        Caches(int ttl) {
            this.ttl = ttl;
        }

        Caches(int ttl, int maxSize) {
            this.ttl = ttl;
            this.maxSize = maxSize;
        }

        private int maxSize = DEFAULT_MAXSIZE;    //最大數量
        private int ttl = DEFAULT_TTL;        //过期时间(秒)

        public int getMaxSize() {
            return maxSize;
        }

        public void setMaxSize(int maxSize) {
            this.maxSize = maxSize;
        }

        public int getTtl() {
            return ttl;
        }

        public void setTtl(int ttl) {
            this.ttl = ttl;
        }
    }

    /**
     * 个性化配置缓存
     */
    @Bean
    public CacheManager cacheManager() {
        SimpleCacheManager manager = new SimpleCacheManager();
        //把各个cache注册到cacheManager中,CaffeineCache实现了org.springframework.cache.Cache接口
        ArrayList<CaffeineCache> caches = new ArrayList<>();
        for (Caches c : Caches.values()) {
            caches.add(new CaffeineCache(c.name(),
                    Caffeine.newBuilder().recordStats()
                            .expireAfterWrite(c.getTtl(), TimeUnit.SECONDS)
                            .maximumSize(c.getMaxSize())
                            .build())
            );
        }
        manager.setCaches(caches);
        return manager;
    }

}

yml配置

server:
  port: 8080
spring:
  cache:
    caffeine:
      spec: maximumSize=500,expireAfterWrite=5s
    type: caffeine
    cache-names:
      - user
      - info

配置启动

package com.km;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cache.annotation.EnableCaching;

@SpringBootApplication
@EnableCaching
public class SpringBootCaffeineCacheApplication {

	public static void main(String[] args) {
		SpringApplication.run(SpringBootCaffeineCacheApplication.class, args);
	}
}


示例

点击下载源码,如果对你有帮助请赏赐一个star

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 缓存来提高性能了。当然,还有其他更多的配置选项和注解可以使用,你可以根据自己的需求进行调整和扩展。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值