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



