SpringBoot集成Caffeine缓存:高性能本地缓存解决方案

SpringBoot集成Caffeine缓存:高性能本地缓存解决方案

一.Caffeine是什么?

Caffeine是一个高性能的Java缓存库,为Java应用程序提供了极快的本地内存缓存解决方案。它是基于Google Guava Cache重新设计的缓存框架,在性能和功能上都有显著提升。Caffeine的核心优势在于其高效的缓存算法和优秀的并发性能,能够显著提升应用程序的响应速度和吞吐量。

二.为什么选择Caffeine?

Caffeine vs Redis

  1. 本地缓存 vs 分布式缓存
    • Caffeine:本地内存缓存,适用于单机应用
    • Redis:分布式缓存,适用于多实例、需要共享缓存的场景
  2. 性能对比
    • Caffeine:读写速度极快,几乎没有网络开销
    • Redis:有网络通信开销,但支持更复杂的缓存策略
  3. 适用场景
    • 选择Caffeine的情况:
      • 单体应用
      • 数据量相对较小
      • 缓存数据不需要在多个服务间共享
      • 对性能要求极高
      • 缓存数据变化不频繁
    • 选择Redis的情况:
      • 分布式系统
      • 需要缓存共享
      • 缓存数据量大
      • 需要复杂的缓存策略
      • 要求数据持久化
      • 需要分布式锁等高级特性

一.引入依赖

xml-dtd 复制代码
<dependency>
    <groupId>com.github.ben-manes.caffeine</groupId>
    <artifactId>caffeine</artifactId>
    <version>3.0.5</version>
</dependency>

二.编写配置类

java 复制代码
@EnableCaching
@Configuration
public class CacheConfig extends CachingConfigurerSupport {

    @Bean("caffeineCacheManager")
    @Primary
    public CacheManager caffeineCacheManager() {
        CaffeineCacheManager cacheManager = new CaffeineCacheManager();
        // 配置缓存策略
        cacheManager.setCaffeine(Caffeine.newBuilder()
                .expireAfterWrite(5, TimeUnit.MINUTES)  // 5分钟后过期
                .initialCapacity(100)                   // 初始容量
                .maximumSize(200));                     // 最大缓存条目
        return cacheManager;
    }
}

三.使用案例

java 复制代码
@Component
public class ItemCache {
    @Autowired
    private ItemConfigDao itemConfigDao;

    /**
     * 根据类型获取物品列表
     * @param itemType 物品类型id
     * @return
     */
    @Cacheable(cacheNames = "item",key = "'itemsByType:'+#itemType")
    public List<ItemConfig> getByType(Integer itemType) {
       return itemConfigDao.getByType(itemType);
    }


    /**
     * 删除缓存
     * @param itemType 物品类型id
     */
    @CacheEvict(cacheNames = "item",key = "'itemsByType:'+#itemType")
    public void evictByType(Integer itemType) {
    }
}
相关推荐
陪我一起学编程36 分钟前
Rust 不可变借用:从规则约束到内存安全的深度思考
后端·rust·编程语言
今日说"法"5 小时前
Rust探秘:所有权转移在函数调用中的表现
开发语言·后端·rust
刘一说6 小时前
深入理解 Spring Boot 嵌入式 Web 容器:从原理到性能调优
前端·spring boot·firefox
你的人类朋友6 小时前
设计模式的原则有哪些?
前端·后端·设计模式
程序员小凯6 小时前
Spring Boot文件处理与存储详解
java·spring boot·后端
2501_938774298 小时前
Leaflet 弹出窗实现:Spring Boot 传递省级旅游口号信息的前端展示逻辑
前端·spring boot·旅游
ruleslol9 小时前
SpringBoot13-文件上传02-阿里云OSS
spring boot
武子康9 小时前
大数据-139 ClickHouse MergeTree 最佳实践:Replacing 去重、Summing 求和、分区设计与物化视图替代方案
大数据·后端·nosql
该用户已不存在9 小时前
7个让全栈开发效率起飞的 Bun 工作流
前端·javascript·后端
蹦跑的蜗牛10 小时前
Spring Boot 使用 Redis 实现消息队列
spring boot·1024程序员节