放进redis的key却一直不存在

开发场景:短时间内重复提交,给系统造成不必要的压力,甚至导致业务数据重复,所以需要再交易进入到业务层时判断是否为重复提交

方案:用方法名+类名+报文经过MD5算法生成一个KEY,判断交易流水号在缓存中是否存在,存在则退出交易,提示重复提交,不存在则放入到缓存中且设置有效时长为5秒

问题:判断是否存在时,一直是不存在

解决方法:打断点获取key,去服务器查找缓存中的key是否一直存在,检查该key的特性

新问题:在服务器已经找到我的key,但是用hasKey方法判断却返回false。

原因: 因为redis默认的序列化方式有问题,而且没有设定redisTemplate的stringRedisTemplate子类导致的

解决方法:redis的工具包中已经有stringRedisTemplate子类,判断的时候用的是redisTemplate.haskey,改为stringTemplate.haskey就可以了

源码如下:

在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐