redis键值出现\xac\xed\x00\x05t\x00&的问题及解决

 更新时间:2023年07月31日 09:29:08   作者:Abstracted  
这篇文章主要介绍了redis键值出现\xac\xed\x00\x05t\x00&的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

redis键值出现\xac\xed\x00\x05t\x00&的问题

在使用redis存放键值对时,发现存放的key和value多了\xac\xed\x00\x05t\x00&的前缀,笔者存放的是字符串,结果如下图所示,出现非预期的前缀。

出现该问题的原因是 

redis template向redis存放使用java对象序列化的值,序列化方式和string的一般方式不同。

明明指定的另一个引文字符串作为key,但是实际存储后却多出来一串奇异字符串,这让笔者好奇心顿时升起来了,决定debug调试一下

从set()方法进入一路对execute()的重载方法向下跟踪,最终来到了一个T result = action.doInRedis(connToExpose);代码处

step into 进入doInRedis方法,

可以看到在一开始传入的匿名对象就是这个ValueDeserializingRedisCallback抽象类的一个匿名子类,并实现了set方法的最后一步,将数据存入redis。

来看看我的字符串key是怎么转化成byte数组的。

对rawKey方法向下追踪…

1.获取Key的序列化器,然后对我们的key进行序列化

进入serialize(key)方法,执行了JdkSerializationRedisSerializer类中的serialize方法。

继续向下跟踪…

最终!!!!

原来是使用了JDK自带的ObjectOutPutStream将我们的String对象序列化成了byte[],

来看看我们把byte数组转回字符串key发现在我原本的key之前确实拼接了乱码的字符串。

RedisTemplate对Key的序列化了解了后,我们在看看对Value的序列化是怎么一回事?

最终结果是同样的使用JDK自带的对象输出流对其进行序列化

在Key和Value都序列化后,将数据存入Redis。

最终总结可以发现一切原因都是这个默认的JdkSerializationRedisSerializerJDKRedis序列化器的序列化方式不能让人接受。

知道了问题所在,这个问题就已经解决了一半了。

我们能不能不使用这个默认的JDKRedis序列化器,自己实现一个或者换一个呢?

很幸运,Spring已经为我们提供了许多类型的序列化器了

一般我们常用的序列化器是Jackson2JsonRedisSerializerStringRedisSerializer这两种。

看名字就知道Jackson2JsonRedisSerializer是将对象序列化成JSON形式的序列化器了。

  • Jackson2JsonRedisSerializer:常用来直接序列化Value对象为JSON字符串。内部使用ObjectMapper
  • StringRedisSerializer:常用来序列化Key,也可以用来序列化Value。

于是乎我们对RedisTemplate进行配置

/**
 * 如果key和value都使用的StringRedisSerializer序列化器,则推荐使用StringRedisTemplate
 *
 * 配置Redis的Key和Value的序列化器
 * @param redisTemplate 从容器中获取RedisTemplate
 * @return 修改后的RedisTemple
 */
@Bean
public RedisTemplate<Object, Object> redisStringTemplate(RedisTemplate<Object, Object> redisTemplate) {
    StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
    redisTemplate.setKeySerializer(stringRedisSerializer);
    // 如果手动将Value转换成了JSON,就不要再用JSON序列化器了。
    // redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(Object.class));
    redisTemplate.setValueSerializer(stringRedisSerializer);
    return redisTemplate;
}

查验结果

key和value的序列化和反序列化都正常了。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Redis实现分布式锁的实例讲解

    Redis实现分布式锁的实例讲解

    在本篇文章里小编给大家整理了一篇关于Redis实现分布式锁的实例讲解内容,有兴趣的朋友们可以学习参考下。
    2021-12-12
  • Redis 数据倾斜产生的原因及问题详解

    Redis 数据倾斜产生的原因及问题详解

    数据倾斜是指在Redis分布式集群(如Redis Cluster或Codis)中,数据(内存占用)或访问请求(QPS)没有均匀地分布到各个节点上,导致部分节点负载过高,而其他节点相对空闲的现象,文章详细介绍了Redis数据倾斜的概念、原因、诊断方法以及解决方案,感兴趣的朋友一起看看吧
    2026-01-01
  • Redis 持久化原理分析和使用建议详解

    Redis 持久化原理分析和使用建议详解

    本文主要介绍了Redis提供的三大持久化机制,即AOF日志、RDB快照以及混合持久化机制,结合图文实例给大家讲解的非常详细,感兴趣的朋友一起看看吧
    2025-02-02
  • 详解Redis分布式锁的原理与实现

    详解Redis分布式锁的原理与实现

    在单体应用中,如果我们对共享数据不进行加锁操作,会出现数据一致性问题,我们的解决办法通常是加锁。下面我们一起聊聊使用redis来实现分布式锁
    2022-06-06
  • Redis实现商品秒杀的示例代码

    Redis实现商品秒杀的示例代码

    本文主要介绍了Redis实现商品秒杀的示例代码,详细介绍了Redis的List、Set和Hash类型,以及使用Redis事务保证原子性的方式,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • redis分布式锁实现示例

    redis分布式锁实现示例

    本文主要介绍了redis分布式锁实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-11-11
  • Redis遍历海量数据的实现示例

    Redis遍历海量数据的实现示例

    本文主要介绍了 Redis遍历海量数据的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-04-04
  • Redis分布式锁python-redis-lock使用方法

    Redis分布式锁python-redis-lock使用方法

    这篇文章主要介绍了Redis分布式锁python-redis-lock使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 一文快速搞懂Redis的几种数据类型方式

    一文快速搞懂Redis的几种数据类型方式

    这篇文章主要介绍了一文快速搞懂Redis的几种数据类型方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Redis高级玩法之利用SortedSet实现多维度排序的方法

    Redis高级玩法之利用SortedSet实现多维度排序的方法

    Redis的SortedSet是可以根据score进行排序的,以手机应用商店的热门榜单排序为例,根据下载量倒序排列。接下来通过本文给大家分享Redis高级玩法之利用SortedSet实现多维度排序的方法,一起看看吧
    2019-07-07

最新评论