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表中已成功任务,若时间已经久远,则批量删除,并打印已删除记录日志。
有更好的方法欢迎沟通交流撒~