美文网首页
Spring Cache基于Redis缓存

Spring Cache基于Redis缓存

作者: 我叫钱多多_ | 来源:发表于2018-09-12 16:52 被阅读0次

    1. Redis

    1.1 基于Redis的Spring Cache

    1.1.1 使用步骤:

    (1). 导入pom依赖:

       < dependency>
           < groupId>org.springframework.boot</groupId>
           < artifactId>spring-boot-starter-cache</artifactId>
       < /dependency>
    

    (2). 创建RedisTemplate 并添加RedisSerializer序列化

           @Bean(name = "redisTemplate1")
            public RedisTemplate<Object, Object> redisTemplate() {
            RedisTemplate<Object, Object> redisTemplate = new RedisTemplate();
            //设置序列化Key的实例化对象
            redisTemplate.setKeySerializer(new GenericJackson2JsonRedisSerializer());
            //设置序列化Value的实例化对象
            redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
            redisTemplate.setConnectionFactory(jedisConnectionFactory());
            return redisTemplate;
        }
    

    (3). 创建CacheManager缓存管理器

        @EnableCaching
        @Configuration
        public class CachingConfig extends CachingConfigurerSupport {
            @Bean
            public CacheManager cacheManager(@Qualifier("redisTemplate1") RedisTemplate<Object, Object> redisTemplate) {
                RedisCacheManager manager = new RedisCacheManager(redisTemplate);
                manager.setUsePrefix(true);
                // 整体缓存过期时间,即所有缓存的时间为3600s,会被缓存自己的缓存时间覆盖,如下stu缓存的过期时间为1000s
                manager.setDefaultExpiration(3600L);
                // 设置缓存过期时间。key和缓存过期时间,单位秒,在@Cacheable注解中使用的value指的是要使用的缓存的名字
                Map<String, Long> expiresMap = new HashMap<>();
                expiresMap.put("stu", 1000L);//设置stu缓存的过期时间为1000s
                manager.setExpires(expiresMap);
                return manager;
            }
        }
    

    ***(4). 在缓存对象的方法前添加注解 ***
    1.1 @Cacheable:在方法执行前Spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据,若没有数据,调用方法并将方法返回值放进缓存;
    1.2 @CachePut:无论怎样都会将方法的返回值放进缓存中;@Cacheable与@CachePut的属性保持一致;
    1.3 @CacheEvict:将一条或多条数据从缓存中删除;
    代码示例:(注:如果没有指定key则将方法参数作为key保存到缓存中)

        public interface StudentService {
            //@CachePut缓存新增或更新的数据到缓存,其中缓存的名字叫“stucache”,数据的key是newStudnet的id
         @CachePut(value = "stucache", key = "#newStudnet.id")
         Student save(Student newStudnet);
             //@CacheEvict从缓存“stucache”中删除id为deid的数据
        @CacheEvict(value = "stucache")
        boolean delete(long deid);
        //缓存key为id的数据到缓存“stucache”中;
        @Cacheable(value = "stucache", key = "#p0")
        Student queryOneStudentById(long id);
        @CachePut(value = "stucache", key = "#updaStudent.id")
        Student updateStudent(Student updaStudent);
        }
    

    (5). 在启动类前面添加@EnableCaching注解开启缓存

    1.1.2 遇到过的问题

    (1). 存储对象序列化问题
    问题描述
    ①所有字符都是以16进制显示的问题
    ②中文字符以16进制显示的问题
    解决办法:
    ①通过redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()),和redisTemplate.setKeySerializer(new GenericJackson2JsonRedisSerializer());设置key-value序列化
    ②只需要在终端开启redis客户端的时候添加--raw(两个中杠)可将中文正确显示;这是客户端的原因和服务没关系;

    相关文章

      网友评论

          本文标题:Spring Cache基于Redis缓存

          本文链接:https://www.haomeiwen.com/subject/ddqbgftx.html