刚遇到同样问题,不想用redis缓存机制,使用map的key值唯一性,解决方法有待验证 使用全局变量,一个订单号只能用一次,用完后就不怕了。大佬们,看看这样会有其他问题吗? //通知结果高并发情况下拦截.全局变量 private Map repeatRequstMap = new ConcurrentHashMap<>(); public String xxx(String orderNo ){ if (repeatRequstMap.get(orderNo) == null) { repeatRequstMap.put(orderNo, orderNo); returnMsg = receiveBaseService.syncFinancial(financeUnifiedOrder); if (returnMsg != null) { logger.error("同步财务接口失败-{}-{}", orderNo, returnMsg); repeatRequstMap.remove(orderNo); return returnMsg; } else { if (repeatRequstMap.size() >= 60) { repeatRequstMap = new ConcurrentHashMap<>(); } } //修改同步系统状态 FinanceUnifiedOrder sync = new FinanceUnifiedOrder(); sync.setId(financeUnifiedOrder.getId()); sync.setSyncStatus("1"); financeUnifiedOrderMapper.updateByPrimaryKeySelective(sync); } return null; }
微信支付成功后,异步通知同时多次通知如何拦截?[图片] 大佬们好 现在开发遇到一个情况,当微信支付完成后,会在同时[时间跨度1秒内]收到2个异步通知,这种情况下应该如何拦截掉多余通知呢? 我的业务逻辑是在收到异步通知后就执行一次,执行前会先去判断支付是否成功,并推送消息给客服,但是由于这个时间过短,所以每一次的判断都会是成功的,都会执行一次业务逻辑,一下会推送两条一样的消息 后端开发框架是larave 有没有什么好的办法屏蔽一次
2021-06-04