问题:使用功能redis设置缓存key的时候,用redis查询工具看发现key前缀多了\xac\xed\x00\x05t\x003。
原因:redis时默认使用JdkSerializationRedisSerializer来进行序列化,这种方式会出现这些乱码。
解决:使用StringRedisSerializer配置redis的序列化方式。
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory connectionFactory){
RedisTemplate template = new RedisTemplate<>();
template.setConnectionFactory(connectionFactory);
//字符串序列化方法
template.setKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new StringRedisSerializer());
template.afterPropertiesSet();
return template;
}
如果在同一个应用中使用缓存,这个问题一般不影响使用,正常获取缓存或者更新缓存都可以。
但如果在不同的应用中使用,且两个应用的redis序列化方式不同,那么可能会产生redis缓存不一致的问题。比如:A应用和B应用redis的序列化方式不同,那么A应用和B应用在使用相同的缓存key时,会产生的两条缓存信息,如果后续更新缓存,两个应用都只会更新自己产生的缓存。
文章讲述了在使用Redis设置缓存key时遇到的乱码问题,由于JdkSerializationRedisSerializer的默认序列化导致key前缀出现非ASCII字符。解决方法是切换到StringRedisSerializer。不同应用的序列化方式不一致可能导致缓存不一致性问题。
2751

被折叠的 条评论
为什么被折叠?



