您现在的位置是:首页 > 文章详情

Springboot 2.0 - 集成redis

日期:2018-12-13点击:322

最近在入门SpringBoot,然后在感慨 SpringBoot较于Spring真的方便多时,顺便记录下自己在集成redis时的一些想法。

 

从springboot官网查看redis的依赖包

 

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

操作redis

 

/*    操作k-v都是字符串的  */ @Autowired StringRedisTemplate stringRedisTemplet;  /*      操作k-v都是对象的  */ @Autowired RedisTemplate redisTemplate; 

redis的包中提供了两个可以操作方法,根据不同类型的值相对应选择。

两个操作方法对应的redis操作都是相同的

stringRedisTemplet.opsForValue() // 字符串  stringRedisTemplet.opsForList() // 列表  stringRedisTemplet.opsForSet() // 集合  stringRedisTemplet.opsForHash() // 哈希  stringRedisTemplet.opsForZSet() // 有序集合 

修改数据的存储方式

在StringRedisTemplet中,默认都是存储字符串的形式;在RedisTemplet中,值可以是某个对象,而redis默认把对象序列化后存储在redis中(所以存放的对象默认情况下需要序列化)

如果需要更改数据的存储方式,如采用json来存储在redis中,而不是以序列化后的形式。

1)自己创建一个RedisTemplate实例,在该实例中自己定义json的序列化格式(org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer)

// 这里传入的是employee对象(employee 要求可以序列化) Jackson2JsonRedisSerializer<Employee> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Employee>(Employee.class); 

2)把定义的格式放进自己定义的RedisTemplate实例中

RedisTemplate<Object,Employee> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnectionFactory); // 定义格式 Jackson2JsonRedisSerializer<Employee> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Employee>(Employee.class); // 放入RedisTemplate实例中 template.setDefaultSerializer(jackson2JsonRedisSerializer); 

参考代码:

@Bean  public RedisTemplate<Object,Employee> employeeRedisTemplate(RedisConnectionFactory redisConnectionFactory)throws UnknownHostException{         RedisTemplate<Object,Employee> template = new RedisTemplate<>();         template.setConnectionFactory(redisConnectionFactory);          Jackson2JsonRedisSerializer<Employee> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Employee>(Employee.class);         template.setDefaultSerializer(jackson2JsonRedisSerializer);         return template;     } 

原理:

@Configuration @ConditionalOnClass({RedisOperations.class}) @EnableConfigurationProperties({RedisProperties.class}) @Import({LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class}) public class RedisAutoConfiguration {     public RedisAutoConfiguration() {     }     @Bean     @ConditionalOnMissingBean(         name = {"redisTemplate"}     ) // 在容器当前没有redisTemplate时运行     public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {         RedisTemplate<Object, Object> template = new RedisTemplate();         template.setConnectionFactory(redisConnectionFactory);         return template;     }     @Bean     @ConditionalOnMissingBean // 在容器当前没有stringRedisTemplate时运行     public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {         StringRedisTemplate template = new StringRedisTemplate();         template.setConnectionFactory(redisConnectionFactory);         return template;     } } 

如果你自己定义了RedisTemplate后并添加@Bean注解,(要在配置类中定义),那么默认的RedisTemplate就不会被添加到容器中,运行的就是自己定义的ReidsTemplate实例,而你在实例中自己定义了序列化格式,所以就会以你采用的格式定义存放在redis中的对象。

更改默认的缓冲

springboot默认提供基于注解的缓冲,只要在主程序类(xxxApplication)标注@EnableCaching,缓冲注解有

@Cachingable、@CachingEvict、@CachingPut,并且该缓冲默认使用的是ConcurrentHashMapCacheManager

当引入redis的starter后,容器中保存的是RedisCacheManager ,RedisCacheManager创建RedisCache作为缓冲组件,RedisCache通过操纵redis缓冲数据

修改redis缓冲的序列化机制

在SpringBoot中,如果要修改序列化机制,可以直接建立一个配置类,在配置类中自定义CacheManager,在CacheManager中可以自定义序列化的规则,默认的序列化规则是采用jdk的序列化

注:在SpringBoot 1.5.6 和SpringBoot 2.0.5 的版本中自定义CacheManager存在差异

参考代码:

// springboot 1.x的版本 public RedisCacheManager employeeCacheManager(RedisConnectionFactory redisConnectionFactory){     // 1、自定义RedisTemplate     RedisTemplate<Object,Employee> template = new RedisTemplate<>();     template.setConnectionFactory(redisConnectionFactory);     Jackson2JsonRedisSerializer<Employee> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Employee>(Employee.class);     template.setDefaultSerializer(jackson2JsonRedisSerializer);     // 2、自定义RedisCacheManager     RedisCacheManager cacheManager = new RedisCacheManager(template);     cacheManager.setUsePrefix(true); // 会将CacheName作为key的前缀     return cacheManager; } // springboot 2.x的版本 /**  * serializeKeysWith() 修改key的序列化规则,这里采用的是StringRedisSerializer()  * serializeValuesWith() 修改value的序列化规则,这里采用的是Jackson2JsonRedisSerializer<Employee>(Employee.class)  * @param factory  * @return  */ @Bean public RedisCacheManager employeeCacheManager(RedisConnectionFactory redisConnectionFactory) { RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()               .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))               .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new Jackson2JsonRedisSerializer<Employee>(Employee.class)));         RedisCacheManager cacheManager = RedisCacheManager.builder(redisConnectionFactory).cacheDefaults(config).build();         return cacheManager;     } 
tip:可以通过查看各版本的org.springframework.data.redis.cache.RedisCacheConfiguration去自定义CacheManager.

因为不同版本的SpringBoot对应的Redis版本也是不同的,所以要重写时可以查看官方是怎么定义CacheManager,才知道怎样去自定义CacheManager。

欢迎工作一到五年的 Java 的工程师朋友们加入的 Java 架构开发:69--28-4--54-39

本群提供免费的学习指导架构资料以及免费的解答

不懂得问题都可以在本群提出来之后还会有职业生涯规划以及面试指导

原文链接:https://my.oschina.net/u/3954808/blog/2988050
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章