Spring Redis Client使用Hessian序列化HINCRBY命令的Bug

前言:

公司自己封装Redis Client架包,使用Hessian协议对Redis中Value值进行序列化。在使用Hash结构的HINCRBY命令,处理序列化异常的问题。下面,我将详细说明一下。

正文:

公司封装Redis Client架包,其实就是把Spring相关Redis代码改了改。所以,我就Spring的相关Redis代码进行复现。

首先,在Spring RedisTemplate中配置HashValue的序列化方式。

HessianRedisSerializer类:

我们在写一个测试类,具体代码如下:

复制代码
    @GetMapping("/test1")
    public String test1(Integer num) {

        if (num == 1) {
            redisTemplate.opsForHash().put("test", "1", "1");
            Object value = redisTemplate.opsForHash().get("test", "1");
            System.out.println(value);
        }

        if (num == 2) {
            redisTemplate.opsForHash().put("test", "2", "你好");
            Object value = redisTemplate.opsForHash().get("test", "2");
            System.out.println(value);
        }
        // 复现问题
        if(num ==3){
            Long l1 = redisTemplate.opsForHash().increment("test", "3", 1);
            System.out.println(l1);
            Object l2 = redisTemplate.opsForHash().get("test", "3");
            System.out.println(l2);
        }

        if (num ==4){
            Long l1 = redisTemplate.opsForValue().increment("test1");
            System.out.println(l1);
            Object l2 = redisTemplate.opsForValue().get("test1");
            System.out.println(l2);
        }

        return "ok";
    }

执行num == 1时,说明添加数字值,经过Hessian协议序列化后,存储到Redis服务端的值的格式:

执行num == 2时,说明添加中午值,经过Hessian协议序列化后,存储到Redis服务端的值的格式:

执行num == 3时,复现HINCRBY的Bug。通过以下截图,可以看出Redis服务端存储值的格式为正常数字值型,不是上述经过Hessian协议序列化后值的格式。所以运行相关代码后,报 反序列化对象失败错误。

执行num == 4时,说明String结构数据,使用String序列化方式没有问题。

最后,我使用画图的形式简单说明一下,为啥会报错。执行Hincrby命令时,直接调用相关命令,不用进行Hessian协议序列化。执行Hget命令时,调用相关命令,返回字节数组,经过Hessian协议序列化反序列化,报错抛异常。执行Hset命令时,先对值进行Hessian协议序列化,然后再执行相关命令。

结论:Redis中不建议使用Hessian作为序列化协议。建议使用JSON或String作为序列化协议。

相关推荐
来杯@Java3 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计
卷毛的技术笔记4 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
云烟成雨TD8 小时前
Spring AI 1.x 系列【33】RAG Advisor 组件与四大分层架构
java·人工智能·spring
yurenpai(27届找实习中)8 小时前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)
数据库·redis·缓存
Trouvaille ~8 小时前
【Redis篇】Set 与 Zset:集合运算与排行榜的终极武器
数据库·redis·缓存·set·跳表·后端开发·zset
J2虾虾9 小时前
Spring AI Alibaba - Tools
服务器·人工智能·spring
J2虾虾11 小时前
Spring AI Alibaba - 人工介入(Human-in-the-Loop)
java·人工智能·spring
J2虾虾11 小时前
Spring AI Alibaba - Skills 技能
人工智能·python·spring
小小工匠12 小时前
Redis - 基本架构:一个键值数据库到底由什么组成
数据库·redis·架构
不懂的浪漫12 小时前
Codex 更新后历史 Session 消失?我写了一个修复官方 Bug 的 Recovery Skill
bug·codex·skill