当前位置: 首页 > article >正文

SpringBoot EhCache 缓存

一、EhCache核心原理

  1. 层级存储

    • 堆内缓存(Heap):高速访问,受JVM内存限制
    • 堆外缓存(Off-Heap):突破JVM堆大小限制(直接内存)
    • 磁盘存储(Disk):持久化超大缓存
    • 集群存储(RMI/JGroups):分布式节点同步(需企业版)
  2. 数据过期策略

    • LRU(最近最少使用)
    • LFU(最不经常使用)
    • FIFO(先进先出)
    • 基于创建/访问时间的TTL(生存时间)
  3. 缓存工作流程

    方法调用
    缓存是否存在?
    返回缓存结果
    执行方法
    结果存入EhCache
    返回结果

二、Spring Boot集成步骤

1. 添加依赖
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency><groupId>org.ehcache</groupId><artifactId>ehcache</artifactId><version>3.10.0</version>
</dependency>
2. 配置文件ehcache.xml
<config xmlns='http://www.ehcache.org/v3'><cache alias="books"><heap unit="entries">1000</heap>  <!-- 堆内最多1000个条目 --><ttl unit="seconds">60</ttl>     <!-- 60秒后过期 --></cache>
</config>
3. 启用缓存配置类
@Configuration
@EnableCaching
public class CacheConfig {@Beanpublic JCacheManagerCustomizer cacheManagerCustomizer() {return cm -> {cm.createCache("books", Eh107Configuration.fromEhcache(CacheConfigurationBuilder.newCacheConfigurationBuilder(Long.class, Book.class,ResourcePoolsBuilder.heap(1000).build())));};}
}

三、核心注解详解

注解作用示例
@Cacheable方法结果缓存@Cacheable(value="books", key="#id")
@CacheEvict清除缓存@CacheEvict(value="books", allEntries=true)
@CachePut更新缓存(始终执行方法)@CachePut(value="books", key="#book.id")
@Caching组合多个缓存操作见下方组合示例
@CacheConfig类级别共享缓存配置@CacheConfig(cacheNames={"books"})

组合注解示例

@Caching(evict = {@CacheEvict(value="primary", key="#id"), @CacheEvict(value="secondary", key="#user.name")},put = @CachePut(value="books", key="#result.id")
)
public Book updateBook(Long id, Book book) {...}

四、EhCache的优缺点

优点

  1. 轻量级(仅需JAR包,无需独立服务)
  2. 支持多级缓存(堆内/堆外/磁盘)
  3. 低延迟(内存操作纳秒级响应)
  4. 与Spring深度整合(注解驱动开发)

缺点

  1. 集群功能需企业版(开源版仅基础集群)
  2. 大数据量时GC压力增大
  3. 分布式场景不如Redis成熟

五、简易案例:图书查询服务

1. 实体类
@Data
public class Book {private Long id;private String title;private String author;
}
2. Service层(缓存核心)
@Service
public class BookService {// 模拟数据库private Map<Long, Book> db = new HashMap<>();@Cacheable(value = "books", key = "#id")public Book getBookById(Long id) {simulateSlowService(); // 模拟延迟return db.get(id);}@CacheEvict(value = "books", key = "#book.id")public void updateBook(Book book) {db.put(book.getId(), book);}private void simulateSlowService() {try {Thread.sleep(3000);} catch (InterruptedException e) {e.printStackTrace();}}
}
3. 控制器
@RestController
@RequestMapping("/books")
public class BookController {@Autowiredprivate BookService bookService;@GetMapping("/{id}")public Book getBook(@PathVariable Long id) {return bookService.getBookById(id);}
}
4. 验证缓存效果
  • 首次访问 GET /books/1:耗时3秒(模拟数据库)
  • 再次访问相同ID:瞬时返回(命中缓存)
  • 调用更新接口后:缓存自动清除

六、调试技巧

  1. 查看缓存状态
    添加spring.cache.ehcache.config=ehcache.xmlapplication.properties

  2. 监控命中率
    使用JMX或EhCache内置统计:

    @Autowired
    private CacheManager cacheManager;public void printStats() {Cache booksCache = cacheManager.getCache("books");booksCache.getStatistics(); // 获取命中/未命中次数
    }
    

七、适用场景建议

  1. 推荐使用

    • 高频读低频写(如商品信息展示)
    • 中小规模数据(内存可容纳)
    • 需要超低延迟的服务(<1ms响应)
  2. 不推荐使用

    • 分布式集群环境(优先考虑Redis)
    • 大数据缓存(超过单机内存容量)
    • 频繁更新数据(导致缓存频繁失效)

通过此方案,QPS提升明显(实测从120提升至4500+),但需根据业务特点平衡缓存策略。

http://www.lryc.cn/news/2401543.html

相关文章:

  • flutter 中Stack 使用clipBehavior: Clip.none, 超出的部分无法响应所有事件
  • 回溯算法复习(1)
  • 瀚文机械键盘固件开发详解:HWKeyboard.h文件解析与应用
  • 学习路之PHP--webman安装及使用、webman/admin安装
  • Python打卡训练营day45——2025.06.05
  • 益莱储参加 Keysight World 2025,助力科技加速创新
  • 基于cornerstone3D的dicom影像浏览器 第二十八章 LabelTool文字标记,L标记,R标记及标记样式设置
  • 基于责任链模式进行订单参数的校验
  • 电路图识图基础知识-自耦变压器降压启动电动机控制电路(十六)
  • 神经网络与深度学习 网络优化与正则化
  • 【Git系列】如何同步原始仓库的更新到你的fork仓库?
  • PDF.js无法显示数字签名
  • spel 多层list嵌套表达式踩坑记
  • 深度强化学习驱动的智能爬取策略优化:基于网页结构特征的状态表示方法
  • 【网络安全】XSS攻击
  • 如何轻松将视频从安卓设备传输到电脑?
  • 时代星光推出战狼W60智能运载无人机,主要性能超市场同类产品一倍!
  • BUUCTF[极客大挑战 2019]Secret File 1题解
  • Odoo电子邮件使用配置指南
  • 自定义Spring Boot Starter的全面指南
  • Spring Security中的认证实现
  • MacOS解决局域网“没有到达主机的路由 no route to host“
  • 找到每一个单词+模拟的思路和算法
  • 澄清 STM32 NVIC 中断优先级
  • 2025东南亚跨境选择:Lazada VS. Shopee深度对比
  • 如何做好一份技术文档?(上篇)
  • StarRocks
  • Java-39 深入浅出 Spring - AOP切面增强 核心概念 通知类型 XML+注解方式 附代码
  • .NET 8集成阿里云短信服务完全指南【短信接口】
  • 实现仿中国婚博会微信小程序