JVM进程缓存 Caffeine

JVM进程缓存 Caffeine

初识Caffeine

Caffeine是一个基于Java8开发的,提供了近乎最佳命中率的高性能的本地缓存库。

ben-manes/caffeine: A high performance caching library for Java (github.com)

实例代码

@Test
void testBasicOps() {
    // 创建缓存对象
    Cache<String, String> cache = Caffeine.newBuilder().build();

    // 存数据
    cache.put("gf", "迪丽热巴");

    // 取数据,不存在则返回null
    String gf = cache.getIfPresent("gf");
    System.out.println("gf = " + gf); 

    // 取数据,包含两个参数:
    // 参数一:缓存的key
    // 参数二:Lambda表达式,表达式参数就是缓存的key,方法体是查询数据库的逻辑
    // 优先根据key查询缓存,如果未命中,则执行参数二的Lambda表达式
    String defaultGF = cache.get("defaultGF", key -> {
        // 这里可以去数据库根据 key查询value
        return "柳岩";
    });
    System.out.println("defaultGF = " + defaultGF);
}

缓存驱逐策略

1、基于容量

// 创建缓存对象
Cache<String, String> cache = Caffeine.newBuilder()
    .maximumSize(1) // 设置缓存大小上限为 1 
    .build();

2、基于时间

// 创建缓存对象
Cache<String, String> cache = Caffeine.newBuilder()
    // 设置缓存有效期为 10 秒,从最后一次写入开始计时 
    .expireAfterWrite(Duration.ofSeconds(10)) 
    .build();

3、基于引用:利用GC来回收缓存数据(不推荐)

在默认情况下,当一个缓存元素过期的时候,Caffeine不会自动立即将其清理和驱逐。而是在一次读或写操作后,或者在空闲时间完成对失效数据的驱逐。

实现缓存

1、声明Bean

@Configuration
public class CaffeineConfig {

    @Bean
    public Cache<Long, Item> itemCache(){
        return Caffeine.newBuilder()
                .initialCapacity(100)
                .maximumSize(10_000)
                .build();
    }

    @Bean
    public Cache<Long, ItemStock> stockCache(){
        return Caffeine.newBuilder()
                .initialCapacity(100)
                .maximumSize(10_000)
                .build();
    }
}

2、使用Cache对象

@Autowired
private Cache<Long, Item> itemCache;
@Autowired
private Cache<Long, ItemStock> stockCache;

// ...

@GetMapping("/{id}")
public Item findById(@PathVariable("id") Long id) {
    return itemCache.get(id, key -> itemService.query()
                         .ne("status", 3).eq("id", key)
                         .one()
                        );
}

@GetMapping("/stock/{id}")
public ItemStock findStockById(@PathVariable("id") Long id) {
    return stockCache.get(id, key -> stockService.getById(key));
}

相关推荐

  1. JVM进程缓存 Caffeine

    2024-05-11 11:28:07       30 阅读
  2. JVM缓存本地缓存Caffeine

    2024-05-11 11:28:07       41 阅读
  3. Caffeine缓存

    2024-05-11 11:28:07       26 阅读
  4. 缓存Caffine

    2024-05-11 11:28:07       33 阅读
  5. Caffeine--缓存组件

    2024-05-11 11:28:07       44 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-11 11:28:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-11 11:28:07       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-11 11:28:07       82 阅读
  4. Python语言-面向对象

    2024-05-11 11:28:07       91 阅读

热门阅读

  1. MATLAB在工程计算领域使用情况

    2024-05-11 11:28:07       34 阅读
  2. vue+elmentuiplus中Table-column 动态添加calss

    2024-05-11 11:28:07       33 阅读
  3. 【skill】实体机安装Windows Server 2022

    2024-05-11 11:28:07       32 阅读
  4. STM32_HAL_RTC_实现获取日期

    2024-05-11 11:28:07       30 阅读
  5. b树和b+树的区别

    2024-05-11 11:28:07       41 阅读
  6. STM32学习和实践笔记(26):USART配置步骤

    2024-05-11 11:28:07       36 阅读
  7. IDEA指定配置文件启动

    2024-05-11 11:28:07       34 阅读