素材巴巴 > 程序开发 >

如何用SpringBoot整合Redis(详细讲解~)

程序开发 2023-09-05 18:56:06

大家好,我是卷心菜。本篇主要讲解用SpringBoot整合Redis,如果您看完文章有所收获,可以三连支持博主哦~,嘻嘻。


文章目录

  • 六、自定义序列化方式
  • 一、前言

    🎁作者简介:在校大学生一枚,Java领域新星创作者,Java、Python正在学习中,期待和大家一起学习一起进步~
    💗个人主页:我是一棵卷心菜的个人主页
    🔶本文专栏:Redis理论和实战
    📕自我提醒:多学多练多思考,编程能力才能节节高!

    二、基本介绍

    三、SpringDataRedis

    四、API的简单认识

    在这里插入图片描述

    五、快速入门

    1、引入依赖

            org.springframework.bootspring-boot-starter-data-redisorg.apache.commonscommons-pool2 
     

    2、配置文件

    spring:redis:# Redis服务器地址host: 19.1.5.11# Redis服务器端口号port: 6379# 使用的数据库索引,默认是0database: 0# 连接超时时间timeout: 1800000# 设置密码password: "123456"lettuce:pool:# 最大阻塞等待时间,负数表示没有限制max-wait: -1# 连接池中的最大空闲连接max-idle: 5# 连接池中的最小空闲连接min-idle: 0# 连接池中最大连接数,负数表示没有限制max-active: 20
     

    3、代码实践

        @Testvoid testOne() {redisTemplate.opsForValue().set("name","卷心菜");String name = (String) redisTemplate.opsForValue().get("name");System.out.println(name); //卷心菜}
     

    问题出现了:当我们使用Redis客户端查看刚刚存入Redis数据库的数据时,结果是这样的:

    在这里插入图片描述

    是因为在使用默认的对象redisTemplate时,会把value值序列化为byte类型,所以就出现了上图的结果。

    在这里插入图片描述

    六、自定义序列化方式

    1、JSON序列化器

    首先要编写一个配置类:

    @Configuration
     public class RedisConfig {@Beanpublic RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory)throws UnknownHostException {// 创建模板RedisTemplate redisTemplate = new RedisTemplate<>();// 设置连接工厂redisTemplate.setConnectionFactory(redisConnectionFactory);// 设置序列化工具GenericJackson2JsonRedisSerializer jsonRedisSerializer =new GenericJackson2JsonRedisSerializer();// key和 hashKey采用 string序列化redisTemplate.setKeySerializer(RedisSerializer.string());redisTemplate.setHashKeySerializer(RedisSerializer.string());// value和 hashValue采用 JSON序列化redisTemplate.setValueSerializer(jsonRedisSerializer);redisTemplate.setHashValueSerializer(jsonRedisSerializer);return redisTemplate;}
     }
     

    当配置好配置类后,再次执行上文的代码就不会出现上述情况了,但是问题又来了,当我们的key是一个对象时,代码如下:

        void testTwo() {redisTemplate.opsForValue().set("person", new Person("卷心菜",21));}
     

    在这里插入图片描述

    问题是:为了在反序列化时知道对象的类型,JSON序列化器会将类的class类型写入json结果中,存入Redis,会带来额外的内存开销.

    2、String序列化器

    为了节省内存空间,我们并不会使用JSON序列化器来处理value,而是统一使用String序列化器,要求只能存储String类型的key和value。当需要存储Java对象时,手动完成对象的序列化和反序列化

    在这里插入图片描述

    代码实践:

        @Autowiredprivate StringRedisTemplate redisTemplate;// JSON工具private static final ObjectMapper mapper = new ObjectMapper();@Testvoid testOne() {redisTemplate.opsForValue().set("name", "卷心菜");}@Testvoid testTwo() throws IOException {Person person = new Person("我是一棵卷心菜", 21);//  手动序列化String json = mapper.writeValueAsString(person);redisTemplate.opsForValue().set("person", json);String personJson = redisTemplate.opsForValue().get("person");// 反序列化Person person1 = mapper.readValue(personJson, Person.class);System.out.println(person1);}
     

    当我们使用String序列化器时,就完美的解决了用Json序列化器的缺陷,运行结果如图所示:

    在这里插入图片描述

    在这里插入图片描述


    感谢阅读,一起进步,嘻嘻~


    标签:

    素材巴巴 Copyright © 2013-2021 http://www.sucaibaba.com/. Some Rights Reserved. 备案号:备案中。