Java缓存搭建需选型+集成+配置三步到位:单机高并发用Caffeine,分布式场景用Redis;Spring Boot中通过依赖、@EnableCaching及YAML配置快速集成;注意键命名、TTL、防穿透及对象序列化。

Java项目中搭建缓存运行环境,核心是选型 + 集成 + 配置三步到位。不推荐从零手写缓存,优先使用成熟方案(如 Caffeine、Redis),根据场景决定本地缓存还是分布式缓存。
选择适合的缓存类型
缓存不是越“重”越好,要匹配业务需求:
- 单机高并发、低延迟读取:用 Caffeine(内存级,无网络开销,支持自动过期、大小限制、统计)
- 多节点共享、需持久化或跨服务访问:用 Redis(建议 6.x+,启用 RESP3 和连接池优化)
- 简单开关/配置类数据:可考虑 Spring Cache 抽象层 + 简单实现(如 ConcurrentMap),但仅限开发测试
Spring Boot 中快速集成 Caffeine
添加依赖后,几行配置即可启用本地缓存:
- Maven 引入:red">
spring-boot-starter-cache 和caffeine - 启用缓存:在启动类加 @EnableCaching
- 配置 Caffeine Bean(application.yml):
spring:
cache:
type: caffeine
caffeine:
spec: maximumSize=500,expireAfterWrite=10m
立即学习“Java免费学习笔记(深入)”;
之后在 Service 方法上加 @Cacheable("user") 即可自动缓存返回值。
接入 Redis 作为分布式缓存
重点不是连上 Redis,而是用对方式:
- 使用 Lettuce 客户端(Spring Boot 2.0+ 默认),支持异步、响应式、连接池复用
- 配置连接池(application.yml)避免连接耗尽:
spring:
redis:
host: localhost
port: 6379
lettuce:
pool:
max-active: 20
max-idle: 10
min-idle: 2
缓存对象需实现 Serializable 或改用 JSON 序列化(推荐 Jackson2JsonRedisSerializer)提升可读性与兼容性。
缓存使用中的关键注意点
配置只是起点,真正影响稳定性和性能的是使用习惯:
- 缓存键要有明确命名空间,比如 "user:detail:{id}",避免 key 冲突
- 设置合理过期时间(TTL),防止脏数据长期滞留;对一致性要求高的场景,配合 @CacheEvict 主动清理
- 避免缓存穿透(查不到还反复查):空值缓存 + 布隆过滤器前置校验
- 禁止直接缓存数据库连接、线程、流等非序列化或有状态对象
基本上就这些。缓存本身不复杂,但容易忽略边界和组合策略。上线前务必压测缓存命中率与 GC 表现。










