天天看点

【Redis】SpringBoot整合Redis源码分析

一.Jedis被替换了

    在SpringBoot2.x之后,原来使用的jedis被替换为了lettuce,从spring-boot-starter-data-redis-2.2.5.RELEASE.pom中可以看出来,为啥被替换了查阅资料是说

jedis:采用的直连,多个线程操作的话,是不安全的,如果想要避免不安全使用jedis pool连接池!更像BIO模式

lettuce:采用netty,实例可以再多个线程中进行共享,不存在线程不安全的情况,可以减少线程的数据,更像NIO模式。

【Redis】SpringBoot整合Redis源码分析

二.Redis自动配置

SpringBoot所有的配置类,都有一个自动配置类,自动配置类都会绑定一个properties配置文件
【Redis】SpringBoot整合Redis源码分析
【Redis】SpringBoot整合Redis源码分析
【Redis】SpringBoot整合Redis源码分析

三.Jedis被替换成lettuce原因

@Bean
    @ConditionalOnMissingBean(
        name = {"redisTemplate"}
    )// 我们可以自己定义一个redisTemplate来替换这个默认的
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        // 默认的 RedisTemplate 没有过多的设置,redis 对象都是需要序列化!
        // 两个泛型都是 Object, Object 的类型,我们后使用需要强制转换 <String, Object>
        RedisTemplate<Object, Object> template = new RedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        return template;
    }

    @Bean
    @ConditionalOnMissingBean// 由于 String 是redis中最常使用的类型,所以说单独提出来了一 个bean!
    public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        StringRedisTemplate template = new StringRedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        return template;
    }
           

 从RedisConnectionFactory中可以看出RedisConnection有两个接口JedisConnectionFactory和LettuceConnectionFactory

public interface RedisConnectionFactory extends PersistenceExceptionTranslator {
    RedisConnection getConnection();

    RedisClusterConnection getClusterConnection();

    boolean getConvertPipelineAndTxResults();

    RedisSentinelConnection getSentinelConnection();
}
           
【Redis】SpringBoot整合Redis源码分析

一个个点击去发现,JedisConnectionFactory里面根本没有注入成功,爆红。所以SpringBoot2.x之后,原来使用的jedis被替换为了lettuce。

四.测试

【Redis】SpringBoot整合Redis源码分析

继续阅读