欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > 关于 Spring自定义缓存管理器 的详细说明,包含两种实现方式的对比和代码示例,并附表格总结

关于 Spring自定义缓存管理器 的详细说明,包含两种实现方式的对比和代码示例,并附表格总结

2025/4/9 12:24:51 来源:https://blog.csdn.net/zp357252539/article/details/146984884  浏览:    关键词:关于 Spring自定义缓存管理器 的详细说明,包含两种实现方式的对比和代码示例,并附表格总结

以下是关于 Spring自定义缓存管理器 的详细说明,包含两种实现方式的对比和代码示例,并附表格总结:


1. 自定义缓存管理器的两种方法

方法1:通过配置文件调整RedisCacheManager

适用场景:简单配置,如修改键前缀、超时时间等。
原理:基于Spring Boot的自动配置,通过修改application.properties参数实现。

方法2:完全自定义代码创建RedisCacheManager

适用场景:复杂自定义(如自定义序列化器、多级缓存、动态配置等)。
原理:通过@Bean显式创建RedisCacheManager实例,完全控制配置。


2. 方法1:通过配置文件消除键前缀并设置超时时间

步骤
  1. 禁用键前缀:设置spring.cache.redis.key-prefix=为空。
  2. 设置全局超时时间:通过spring.cache.redis.time-to-live配置。
配置示例
# application.properties
spring.cache.type=redis
spring.cache.redis.key-prefix= # 禁用前缀
spring.cache.redis.time-to-live=1800000 # 全局超时时间:30分钟
效果
  • 缓存键无前缀(如直接使用user:1001)。
  • 所有缓存项默认过期时间为30分钟。

3. 方法2:完全自定义代码创建RedisCacheManager

步骤
  1. 创建配置类:通过@Bean定义RedisCacheManager
  2. 配置序列化器、超时时间等:使用RedisCacheConfiguration
代码示例
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.serializer.*;import java.time.Duration;@Configuration
public class RedisConfig {@Beanpublic RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {// 1. 定义缓存配置RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig().serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())) // 键序列化为字符串.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())) // 值序列化为JSON.entryTtl(Duration.ofMinutes(30)); // 默认超时时间30分钟// 2. 禁用键前缀config = config.prefixCacheNameWithFalse(); // 关键代码:禁用前缀// 3. 创建RedisCacheManagerreturn RedisCacheManager.builder(redisConnectionFactory).cacheDefaults(config).build();}
}
关键点
  • 禁用前缀prefixCacheNameWithFalse()
  • 自定义序列化:如StringRedisSerializerGenericJackson2JsonRedisSerializer
  • 动态配置:可为不同缓存设置不同的超时时间(如通过RedisCacheWriter)。

4. 对比表格

方法适用场景配置方式代码示例片段是否支持复杂自定义
配置文件调整简单配置(前缀、超时)修改application.propertiesspring.cache.redis.key-prefix=
自定义代码复杂配置(序列化、多级缓存)通过@Bean显式创建RedisCacheManagerRedisCacheConfiguration config = ...

5. 关键配置参数说明

方法1(配置文件)
参数描述示例值
spring.cache.redis.key-prefix缓存键的全局前缀(设为空禁用)""(禁用前缀)
spring.cache.redis.time-to-live全局缓存过期时间(毫秒)1800000(30分钟)
方法2(代码配置)
参数描述示例值
serializeKeysWith()自定义键的序列化方式StringRedisSerializer
serializeValuesWith()自定义值的序列化方式GenericJackson2JsonRedisSerializer
entryTtl()设置默认超时时间Duration.ofMinutes(30)
prefixCacheNameWith()启用/禁用缓存名称作为前缀(如prefixCacheNameWithFalse()禁用)prefixCacheNameWithFalse()

6. 注意事项

  1. 方法1的局限性

    • 仅能通过有限的配置参数调整(如前缀、超时),无法自定义序列化器或复杂逻辑。
    • 全局配置可能覆盖单个缓存的自定义设置。
  2. 方法2的优势

    • 完全控制配置(如多级缓存、动态超时)。
    • 需要依赖注入RedisConnectionFactoryRedisTemplate
  3. 禁用键前缀的注意事项

    • 确保缓存键唯一,避免不同业务的键冲突。
    • 若需多级缓存,可通过cacheManager(builder -> builder.withCacheConfiguration(...))为不同缓存命名空间设置前缀。

7. 完整代码示例(方法2)

@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {RedisTemplate<String, Object> template = new RedisTemplate<>();template.setConnectionFactory(factory);template.setKeySerializer(new StringRedisSerializer());template.setValueSerializer(new GenericJackson2JsonRedisSerializer());return template;}@Beanpublic RedisCacheManager cacheManager(RedisConnectionFactory factory) {// 1. 定义默认配置RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofMinutes(30)).serializeKeysWith(SerializationPair.fromSerializer(new StringRedisSerializer())).serializeValuesWith(SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())).prefixCacheNameWithFalse(); // 禁用前缀// 2. 为特定缓存设置不同配置(可选)config = config.disableCachingNullValues(); // 禁止缓存空值// 3. 创建缓存管理器return RedisCacheManager.builder(factory).cacheDefaults(config).build();}
}

总结

通过上述两种方法,可以灵活控制Redis缓存管理器的配置。对于简单需求,优先使用配置文件调整;对于复杂场景(如自定义序列化、多级缓存),推荐通过代码完全自定义。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词