介于看我文章的都是大神,所以我这些spring boot 入门教程文章就不按部就班的写自动装配,什么依赖管理了,我就直接从项目中实际用到的组件整合文章,像mybatis、redis、kafka、rocketMq、es等等,因为我之前是做气象大数据的,spring boot的es api封装的不太好,所以我有一套关于es的奇技淫巧,对es有期待的,就关注我把。spring boot版本是最新的稳定版2.5.3,我这个人向来有个特点,有新的不用旧的。没用过不得试一试吗。话不多说,上代码。
1.pom添加redis依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
spring boot 2.x以后已经将默认的jedis欢成了lettuce,这里说一下为什么要从jedis替换成lettuce。
- jedis:采用的是直连,多个线程操作的话,是不安全的。避免不安全情况,只能采用jedis pool连接池。线程数量多的话,redis-server会变的非常大,类似于BIO(阻塞的)。
- Lettuce的连接是基于Netty的,连接实例(StatefulRedisConnection)可以在多个线程间并发访问,应为StatefulRedisConnection是线程安全的,所以一个连接实例(StatefulRedisConnection)就可以满足多线程环境下的并发访问,当然这个也是可伸缩的设计,一个连接实例不够的情况也可以按需增加连接实例。
2. application.yml配置
server:
port: 9101
spring:
application:
name: redistest
jmx:
default-domain: redistest
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
redis:
database: 1
host: 192.168.16.134
port: 6379
password: summer123
3.重写RedisTemplate
这里讲下为什么spring boot已经帮我们实现好了两种序列化方案,我们还要自己去重写 一些。首先RedisTemplate<Object,Object> 他的泛型都是Object,序列化方案是JDK默认的,写入到数据库时,会被转成16进制,查看起来十分不友好。第二种RedisTemplate<String,String> 则要求值和value都为string,在实际编码中,我们是想得到一个RedisTemplate<String,Object>的模板,所以我们要重写。
@Configuration
public class RedisConfig {
@Bean
@SuppressWarnings("all")
public RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory redisConnectionFactory){
RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
template.setConnectionFactory(redisConnectionFactory);
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.activateDefaultTyping(LaissezFaireSubTypeValidator.instance , ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.PROPERTY);
jackson2JsonRedisSerializer.setObjectMapper(om);
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
// key采用String的序列化方式
template.setKeySerializer(stringRedisSerializer);
// hash的key也采用String的序列化方式
template.setHashKeySerializer(stringRedisSerializer);
// value序列化方式采用jackson
template.setValueSerializer(jackson2JsonRedisSerializer);
// hash的value序列化方式采用jackson
template.setHashValueSerializer(jackson2JsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
}
4.测试代码(因为redisutils 网上一搜一大堆,这里就不给大家上代码了,主要就是讲了一个简单的集成,也没有深入展开)
@SpringBootTest
class SpringbootRedisApplicationTests {
@Resource
RedisTemplate<String, Object> redisTemplate;
@Test
void contextLoads() {
redisTemplate.opsForValue().set("zdish","www.zdish.cn");
String value = redisTemplate.opsForValue().get("zdish").toString();
System.err.println(value);
}
}
以上就是spring boot 整合redis的全部内容,下面会再继续几篇文章讲解基于注解的缓存实现、redis的发布订阅实现、基于redis的分布式锁等关于redis的高阶玩法。