Redis缓存之自定义CacheManager

测试缓存:
原理:
CacheManager===Cache 缓存组件来实际给缓存中存储数据
1,引入redis的starter,容器中保存的是RedisCacheManager
2,RedisCacheManager 帮我们创建RedisCache 来作为缓存组件;
RedisCache通过操作redis来缓存数据
3,默认保存数据 K -V 都是通过序列化来保存的;

 

关于能存储redis。第二次查不能反序列化出来的问题。
原因:存的是dept的缓存数据,而CacheManager默认使用RedisTemplate<Object, Employee>来操作redis
解决方法:
自定义CacheManager:
1> 引入了redis的starter,cacheManager变为RedisCacheManager
2> 默认创建的RedisCacheManager 操作redis的时候使用的是 RedisTemlate<Object,Object>
3> RedisTemlate<Object,Object> 是默认使用jdk序列化机制
4> 自定义CacheManager

@Configuration
public class MyRedisConfig {

    //员工缓存
    @Bean
    public RedisTemplate<Object, Employee> empRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        RedisTemplate<Object, Employee> template = new RedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        Jackson2JsonRedisSerializer<Employee> ser = new Jackson2JsonRedisSerializer<Employee>(Employee.class);
        template.setDefaultSerializer(ser);
        return template;
    }

    //员工缓存
    //CacheManagerCustomizers 可以定制缓存的一些规则
    @Bean
    @Primary  //默认缓存管理器  必须得有默认
    public RedisCacheManager employeeCacheManager(RedisTemplate<Object, Employee> empRedisTemplate) {
        RedisCacheManager cacheManager = new RedisCacheManager(empRedisTemplate);
        //key多了一个前缀

        //使用前缀,默认把cacheName作为前缀
        cacheManager.setUsePrefix(true);
        return cacheManager;
    }


    //部门缓存
    @Bean
    public RedisTemplate<Object, Department> deptRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        RedisTemplate<Object, Department> template = new RedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        Jackson2JsonRedisSerializer<Department> ser = new Jackson2JsonRedisSerializer<Department>(Department.class);
        template.setDefaultSerializer(ser);
        return template;
    }

    //部门缓存
    @Bean
    public RedisCacheManager deptCacheManager(RedisTemplate<Object, Department> deptRedisTemplate) {
        RedisCacheManager cacheManager = new RedisCacheManager(deptRedisTemplate);
        cacheManager.setUsePrefix(true);
        return cacheManager;
    }
}

 

  1. @Primary 当自定义两个CacheManager的时候。必须指定一个为默认的

  2. 针对不同的service可以直接标注CacheManager,同时如果有默认指定,可以省略不写
    @CacheConfig(cacheNames = "dept",cacheManager = "deptCacheManager")
    @Service
    public class DeptService {
    @CacheConfig(cacheNames = "emp"/*,cacheManager = "employeeCacheManager"*/)
    @Service
    public class EmployeeService {
  3. 以上都是注解形式的缓存,编码形式的缓存写法:
       //方法内,编码方式做缓存
        @Qualifier("deptCacheManager")
        @Autowired
        RedisCacheManager deptCacheManager;
    
     //在方法内做缓存写法
        public Department getDeptById(Integer id){
            System.out.println("查询部门id为"+id+"...........");
            Department dept =  departmentMapper.getDeptById(id);
            Cache deptCache=deptCacheManager.getCache("dept");//相当于 @Cacheable(cacheNames = "dept")
            deptCache.put("dept:1",dept);
            return  dept;
        }

     

 

转载于:https://www.cnblogs.com/MagicAsa/p/10791523.html

RedisCacheManager是Spring提供的一个缓存管理器,用于将数据缓存Redis中。如果需要自定义RedisCacheManager,可以继承它并重写相关方法。 首先,需要创建一个类,继承RedisCacheManager: ``` public class CustomRedisCacheManager extends RedisCacheManager { public CustomRedisCacheManager(RedisOperations redisOperations) { super(redisOperations); } @Override protected RedisCache createCache(String cacheName) { // 自定义缓存实现 return new CustomRedisCache(cacheName, (isUsePrefix() ? getCachePrefix().prefix(cacheName) : null), getRedisOperations(), getExpiration()); } } ``` 在这个类中,我们重写了createCache方法,用于创建自定义缓存实现。我们可以创建一个CustomRedisCache类,继承RedisCache,然后在这个类中实现自己的缓存逻辑。 例如,下面是一个简单的CustomRedisCache实现: ``` public class CustomRedisCache extends RedisCache { public CustomRedisCache(String name, byte[] prefix, RedisOperations<? extends Object, ? extends Object> redisOperations, long expiration) { super(name, prefix, redisOperations, expiration); } @Override public ValueWrapper get(Object key) { // 自定义缓存逻辑 return super.get(key); } @Override public void put(Object key, Object value) { // 自定义缓存逻辑 super.put(key, value); } @Override public void evict(Object key) { // 自定义缓存逻辑 super.evict(key); } @Override public void clear() { // 自定义缓存逻辑 super.clear(); } } ``` 在这个CustomRedisCache类中,我们重写了RedisCache中的get、put、evict和clear方法,用于实现自己的缓存逻辑。 最后,在Spring配置文件中,使用自定义RedisCacheManager代替默认的RedisCacheManager。例如: ``` <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <!-- Redis连接工厂 --> <property name="connectionFactory" ref="redisConnectionFactory"/> <!-- Redis序列化工具 --> <property name="valueSerializer" ref="jackson2JsonRedisSerializer"/> <property name="hashValueSerializer" ref="jackson2JsonRedisSerializer"/> </bean> <bean id="cacheManager" class="com.example.CustomRedisCacheManager"> <constructor-arg ref="redisTemplate"/> <property name="cacheNames"> <list> <value>cache1</value> <value>cache2</value> </list> </property> <property name="defaultExpiration" value="60"/> </bean> ``` 在这个配置中,我们创建了一个CustomRedisCacheManager,并设置了缓存名称和默认过期时间。注意,这里的redisTemplate需要自己定义,并设置好相关属性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值