springboot 2.x入门(三)——springboot2.x 整合redis

        介于看我文章的都是大神,所以我这些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的高阶玩法。

        大家可以关注我的网站www.zdish.cn。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值