• 【SimpleFunction系列一】SpringBoot整合Redis(含序列化问题)


    版本说明(代码在GitHub👆🏻)

    基于simple_functions项目1.0.0分支开发

    1.00:初始化hello接口
    1.10:整合Redis

    SpringBoot整合Redis

    Redis几乎是目前项目必备的缓存工具了。

    java中连接Redis的方式有很多方案:【官网Java连接Redis方式】

    请添加图片描述

    为了方便使用,SpringData为我们提供了SpringDataRedis。

    在 Spring Boot 中,默认集成的 Redis 就是 Spring Data Redis,默认底层的连接池使用了 lettuce ,开发者可以自行修改为自己的熟悉的,例如 Jedis。

    Spring Data Redis 针对 Redis 提供了非常方便的操作模板 RedisTemplate 。

    这是 Spring Data 擅长的事情,那么接下来我们就来看看 Spring Boot 中 SpringData Redis 的具体用法。

    引入依赖

    starter和连接池

    
    <dependency>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-data-redisartifactId>
    dependency>
    <dependency>
        <groupId>org.apache.commonsgroupId>
        <artifactId>commons-pool2artifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    配置Redis信息

    lettuce可以换成上面图中的其他组件

    spring:
      redis:
        host: 127.0.0.1
        port: 6379
        lettuce:
          pool:
            max-active: 100 # 连接池最大连接数(使用负值表示没有限制)
            max-idle: 100 # 连接池中的最大空闲连接
            min-idle: 50 # 连接池中的最小空闲连接
            max-wait: 6000ms # 连接池最大阻塞等待时间(使用负值表示没有限制)
        timeout: 6000ms
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    编写一个工具类

    RedisUtils.java

    测试

    @GetMapping("/hello/{value}")
    public String Hello(@PathVariable String value){
        redisUtils.set("hello",value,100);
        return "设置成功";
    }
    
    @GetMapping("/getHello")
    public String getHello(){
        return redisUtils.get("hello");
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    Redis序列化问题

    使用RedisTemplate存储对象如果使用可视化工具查看,无法看到明确的存储内容,看到的是一串16进制字符,十分不方便。

    请添加图片描述

    因为其默认使用的是JDK序列化方式。这里helloObj的key不是乱码是因为我设置了key的序列化方式为String

    推荐打开方式为下方配置代码中第二个,使用JSON序列化类

    下面是设置方式:

    @Configuration
    @RequiredArgsConstructor
    public class RedisConfig {
    
        private final RedisConnectionFactory factory;
    
        @Bean
        public RedisTemplate<String, Object> redisTemplate() {
            RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
            redisTemplate.setKeySerializer(new StringRedisSerializer());
            redisTemplate.setHashKeySerializer(new StringRedisSerializer());
    //        redisTemplate.setHashValueSerializer(new StringRedisSerializer());
    //        redisTemplate.setValueSerializer(new StringRedisSerializer());
            redisTemplate.setConnectionFactory(factory);
            return redisTemplate;
        }
    
        @Bean
        @Qualifier("helloWordRedisCache")
        public RedisTemplate<String, HelloWord> helloWordRedisCache(){
            RedisTemplate<String, HelloWord> redisTemplate = new RedisTemplate<>();
            redisTemplate.setKeySerializer(new StringRedisSerializer());
            redisTemplate.setHashKeySerializer(new FastJsonRedisSerializer<>(HelloWord.class));
            redisTemplate.setHashValueSerializer(new StringRedisSerializer());
            redisTemplate.setValueSerializer(new FastJsonRedisSerializer<>(HelloWord.class));
            redisTemplate.setConnectionFactory(factory);
            return redisTemplate;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    StringRedisTemplate默认的序列化方式就是String,因此value只能是String类型,如国上面的RedisTemplate配置中将注释部分打开其值就也只能设置为String了。
    请添加图片描述

    Demo

    private final RedisTemplate<String, HelloWord> helloWordRedisCache;
    private final RedisTemplate<String, Object> redisTemplate;
    
    @GetMapping("/hello/{value}")
    public String Hello(@PathVariable String value){
        redisUtils.set("hello",value,100);
        HelloWord word = helloWordService.getById(1);
        redisTemplate.opsForValue().set("helloObj",word, 10, TimeUnit.SECONDS);
        helloWordRedisCache.opsForValue().set("helloHello",word, 10, TimeUnit.SECONDS);
        return "设置成功";
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    【详细了解Redis序列化问题】

  • 相关阅读:
    运营︱内容营销怎么做?
    C#服务器端代码
    09链表-单链表移除元素
    每天五分钟深度学习:神经网络和深度学习有什么样的关系?
    Ubantu GoLand安装
    大模型Agent最新论文及源码合集,覆盖构建、应用、评估
    【无标题】
    【数据聚类】基于粒子群、遗传和差分算法实现数据聚类附matlab代码
    利用不同类型数据构建系统发育树
    免交互 实验
  • 原文地址:https://blog.csdn.net/qq_38723677/article/details/126041333