Spring Cache基于Redis缓存

2018-09-12  本文已影响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(两个中杠)可将中文正确显示;这是客户端的原因和服务没关系;

上一篇下一篇

猜你喜欢

热点阅读