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

ops/2024/12/14 10:17:09/

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

一.Caffeine是什么?

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

二.为什么选择Caffeine?

Caffeine vs Redis

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

一.引入依赖

<dependency><groupId>com.github.ben-manes.caffeine</groupId><artifactId>caffeine</artifactId><version>3.0.5</version>
</dependency>

二.编写配置类

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

三.使用案例

@Component
public class ItemCache {@Autowiredprivate 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) {}
}

http://www.ppmy.cn/ops/141788.html

相关文章

arXiv-2024 | VLM-GroNav: 基于物理对齐映射视觉语言模型的户外环境机器人导航

作者&#xff1a; Mohamed Elnoor, Kasun Weerakoon, Gershom Seneviratne, Ruiqi Xian, Tianrui Guan, Mohamed Khalid M Jaffar, Vignesh Rajagopal, and Dinesh Manocha单位&#xff1a;马里兰大学学院公园分校原文链接&#xff1a;VLM-GroNav: Robot Navigation Using Phys…

初始Python篇(11)—— 面向对象三大特征

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; Python 目录 封装 继承的基本概念以及使用 继承 继承的基本概念以及使用 方法重写 多态 多态的概念以及基本使用 封装 继承的基本…

PHP和GD如何根据颜色生成渐变效果

在PHP中&#xff0c;使用GD库可以很方便地生成颜色渐变效果。GD库是PHP中用于处理图像的扩展库&#xff0c;支持创建图像、绘制图形、处理图像等多种功能。下面是一个基本的步骤&#xff0c;介绍如何使用PHP和GD库根据颜色生成渐变效果&#xff1a; 步骤 创建图像资源&#xf…

NIO 三大组件

NIO 基础 non-blocking-io 非阻塞IO 1. 三大组件 1.1 Channel & Buffer channel 有一点类似与strem&#xff0c;他就是读写数据的双向通道&#xff0c;可以从channel将数据读入buffer&#xff0c;也可以将buffer写入channel&#xff0c;而之前的strem要么是输入&#x…

数据采集:各地区动态IP数据质量差异分析

“在当今信息化社会&#xff0c;数据采集已成为各行各业不可或缺的一部分&#xff0c;它为企业决策、市场分析、学术研究等提供了重要的数据支持。而在数据采集过程中&#xff0c;动态IP作为一种频繁更换IP地址的代理服务&#xff0c;因其能够模拟不同地理位置的用户访问、突破…

算法2(蓝桥杯19)-合并两个有序链表

问题&#xff1a;将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 解题思路&#xff1a; 创建一个虚拟节点&#xff0c;循环比较l1、l2链表各节点的大小&#xff0c;将较小的节点追加到虚拟节点后&#xff0c;返回新链表 1、…

quartz 架构详解

‌Quartz是一个开源的作业调度框架&#xff0c;完全由Java编写&#xff0c;主要用于定时任务的调度和管理。Quartz的架构主要包括以下几个核心组件‌&#xff1a; 1.‌调度器&#xff08;Scheduler&#xff09;‌&#xff1a;调度器是Quartz的核心组件&#xff0c;负责管理Qua…

MySQL有哪些高可用方案?

大家好&#xff0c;我是锋哥。今天分享关于【MySQL有哪些高可用方案?】面试题。希望对大家有帮助&#xff1b; MySQL有哪些高可用方案? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MySQL 高可用方案旨在确保数据库系统的高可靠性、低宕机时间、以及在硬件故障…