现在的应用系统功能越來越多复杂度也相应增大,而在线商城大都是分布式环境的在商城系统中怎么保证支付宝关闭短信通知的异步通知一定会被正确处理。
这是支付宝关闭短信通知的异步通知当买家付完款后,支付宝关闭短信通知会向这个地址发送post请求其带了N多参数,然后验證签名是否正确签名通过返回success,签名不通过返回false。我们处理订单的逻辑就是写在这个位置的
在这个方法里,不建议做太多的与数据库相關的操作因为每个买家付完款款后,都会调用这个接口所以只将消息存在可靠消息服务里,并立马返回支付宝关闭短信通知注意这個接口要做成幂等操作,防止网络故障没有给支付宝关闭短信通知响应,支付宝关闭短信通知就会一直调这个接口
下图就是可靠消息實现方案
可靠消息主要是用来保证消息不丢失的。
①主动方发送预确认消息
②将消息存储在数据库中状态为待确认
④根据返回的结果判斷事都执行业务方法,业务方法完成后发送确认消息
⑤独立消息服务将消息扔到消息队列(MQ)中
⑥被动方应用监听队列取出消息消费
消息┅致性异常处理 :定时的从可靠消息服务中取出消息状态是待确认的超过一定时间没被确认,调用主动方应用提供的查询业务方法结果嘚接口根据结果对该消息进行操作,删除或者更改状态为发送中并扔到MQ中。
消息消费异常处理:定时的从可靠消息服务中取出消息状態是发送中的超过一定时间还没有被确认消费的,将该消息扔到MQ中
死亡消息处理 :如果消息多次扔到MQ当中,还是未成功消息就要将該消息置为已死亡,有可靠消息的管理页面处理
发布了69 篇原创文章 · 获赞 4 · 访问量 4万+