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) {
    }
}
相关推荐
JaguarJack3 分钟前
PHP 图像处理实战 GD/Imagick 从入门到精通,构建高性能图像服务
后端·php
摇滚侠4 分钟前
Spring Boot中使用线程池来优化程序执行的效率!笔记01
java·spring boot·多线程
海梨花2 小时前
今日八股——JVM篇
jvm·后端·面试
Pr Young7 小时前
服务优雅停止和服务优雅启动
后端
嘟嘟MD8 小时前
程序员副业 | 2025年9月复盘
后端·aigc
尘觉8 小时前
中秋节与 Spring Boot 的思考:一场开箱即用的团圆盛宴
java·spring boot·后端
间彧9 小时前
Seata分布式事务框架详解与项目实战
后端
zhuyasen9 小时前
单机已达上限?PerfTest 分布式压测登场,轻松模拟百万用户洪峰
后端·性能优化·测试
勇哥java实战分享9 小时前
sensitive-word:一个简单易用的敏感词过滤框架
后端
popoxf9 小时前
spring容器启动流程(反射视角)
java·后端·spring