放进redis的key却一直不存在
开发场景:短时间内重复提交,给系统造成不必要的压力,甚至导致业务数据重复,所以需要再交易进入到业务层时判断是否为重复提交
方案:用方法名+类名+报文经过MD5算法生成一个KEY,判断交易流水号在缓存中是否存在,存在则退出交易,提示重复提交,不存在则放入到缓存中且设置有效时长为5秒
问题:判断是否存在时,一直是不存在
解决方法:打断点获取key,去服务器查找缓存中的key是否一直存在,检查该key的特性
新问题:在服务器已经找到我的key,但是用hasKey方法判断却返回false。
原因: 因为redis默认的序列化方式有问题,而且没有设定redisTemplate的stringRedisTemplate子类导致的
解决方法:redis的工具包中已经有stringRedisTemplate子类,判断的时候用的是redisTemplate.haskey,改为stringTemplate.haskey就可以了
源码如下:


在开发中遇到一个问题,当尝试使用MD5方法生成的key来检查Redis中是否存在交易流水号时,发现使用`redisTemplate.hasKey()`始终返回false。深入调查后,发现原因是Redis的默认序列化方式及未指定`stringRedisTemplate`导致的问题。解决方案是切换到`stringRedisTemplate.hasKey()`进行key的判断,从而解决了问题。
137

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



