Redis线上部署乱码:如何解决Key和Value值乱码问题?

Redis线上部署乱码问题及解决方案

在将Redis从本地或Windows环境迁移到线上服务器后,经常遇到Key和Value值出现乱码的情况。本文将分析此问题,并提供有效的解决方案。

问题描述

本地测试环境下Redis数据存取正常,但部署到线上服务器后,却出现Key前缀和Value值乱码的问题。

问题分析

初步怀疑是序列化方式导致的问题。因此,尝试将jdkserializationredisserializer替换为stringredisserializer

解决方案

经排查,发现业务逻辑中存在删除Value的需求,但线上服务器禁用keys命令。乱码导致删除操作失败,因此必须解决乱码问题。

使用stringredistemplate存储数据后,Key和Value乱码问题得以解决。然而,由于Value值现在以JSON字符串形式存储,需要在存储和读取时进行相应的转换处理:

  • 存储前: 将对象转换为JSON字符串。
  • 读取后: 去除JSON字符串中的双引号和转义符,再将JSON字符串转换为对象。

代码示例

存储数据:

String jsonString = JSON.toJSONString(baseModelList); 

读取数据:

String strip = StrUtil.strip(jsonString, "\""); //去除双引号
String unescapedJson = StringEscapeUtils.unescapeJava(strip); //去除转义符
List baseModelList = JSON.parseArray(unescapedJson, BaseModel.class);

通过以上步骤,可以有效解决Redis线上部署中出现的乱码问题,确保数据的

正确存储和读取。 注意选择合适的JSON库(例如fastjson, jacksongson)并根据实际项目情况调整代码。