订单退款与退款失败任务重试

1.系统老退款步骤
用户提交退款申请->校验后执行退款相关处理->处理结果反馈。

2.系统现有退款步骤
用户提交退款申请->简单处理反馈->发送退款消息做复杂处理->最终结果反馈

3.改进后退款步骤
退款任务
用户提交退款申请->简单校验处理->在task表中生成任务记录,新增status为RUNING,同时发消息退款消息->消息消费者监听消息,处理退款操作->处理成功,更改task表中status为SUCCESS。处理失败更改task表中status为INIT。

异步task1
定期扫描task表中status,发现status为INIT的并且retry_times字段没有超过限制,取出处理(发消息),消息消费端发现已经成功->更改task表状态为SUCCESS。处理失败,若已达到最大重试次数限制,更改status为FAIL,否则不变。

异步task2
定期扫描task表中已成功任务,若时间已经久远,则批量删除,并打印已删除记录日志。

有更好的方法欢迎沟通交流撒~

发布了26 篇原创文章 · 获赞 68 · 访问量 26万+

猜你喜欢

转载自blog.csdn.net/qq_32193151/article/details/71151868