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

关于 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 {

    @Bean
    public 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. 创建RedisCacheManager
        return 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 {

    @Bean
    public 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;
    }

    @Bean
    public 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缓存管理器的配置。对于简单需求,优先使用配置文件调整;对于复杂场景(如自定义序列化、多级缓存),推荐通过代码完全自定义。

http://www.dtcms.com/a/113500.html

相关文章:

  • 复古未来主义屏幕辉光像素化显示器反乌托邦效果PS(PSD)设计模板样机 Analog Retro-Futuristic Monitor Effect
  • 多线程代码案例 - 2
  • 高速电路 PCB 设计要点二
  • 【代码模板】如何用FILE操作符打开文件?fopen、fclose
  • KUKA机器人软件WorkVisual更改语言方法
  • Springboot定时任务开发
  • Java 大视界 -- Java 大数据在智能医疗远程护理与患者健康管理中的应用与前景(175)
  • 游戏引擎学习第205天
  • infinityfree最新免费建站详细教程_无需备案_5G空间_无限流量_免费域名_免费SSL
  • [巴黎高师课程] 同步反应式系统(2024-2025)第三课 - Kind 2: 基于SMT的Lustre模型检查器
  • 快速解决 Java 服务 CPU 过高问题指南
  • Tomcat的部署
  • 泡棉压缩对显示模组漏光的定位分析及论述
  • C 语言函数四(递归)
  • Node.js核心模块及Api详解
  • 【Block总结】PlainUSR的局部注意力,即插即用|ACCV2024
  • Synopsys:设计对象
  • Scade One - 可视化编程体验
  • 如何高效使用 Ubuntu 中文官方网站
  • 【含文档+PPT+源码】基于Python的股票数据可视化及推荐系统的设计与实现
  • MobileDet(2020➕CVPR)
  • Unity:销毁(Destroy)
  • Qt多线程从基础到性能优化
  • 尚硅谷2019版多线程以及枚举类笔记记录
  • 量化交易----从0到1
  • 【开题报告+论文+源码】基于SpringBoot+Vue的爱家园管理系统
  • 一天一个java知识点----多线程
  • 虚拟Ashx页面,在WEB.CONFIG中不添加handlers如何运行
  • Linux系统之chkconfig命令详解
  • P1036 [NOIP 2002 普及组] 选数(DFS)