场景: 前台请求后台接口,但是后台接口性能不佳,导致请求超时,或被预警系统记录慢接口
解决方案1:
分析出是哪里慢,性能瓶颈在哪进行解决处理(治本)
解决方案2:
异步处理: 将一个接口设计拆分为两个接口 ,第一个接口为业务接口,第二个接口为处理进度接口。
1.先请求第一个接口,生成一个uuid,然后异步处理业务,再返回uuid给前台。
1.1.异步处理完业务时,将处理结果封装到对象中(处理状态,响应消息等等),然后转成json字符串保存到redis中,key为uuid(可以自定义前缀拼接uuid),value为json字符串,再设置过期时间。
2.前台拿到返回的uuid后,将uuid作为入参循环查询第二个接口,直到业务接口处理完成(根据返回状态判断)。
2.1 接口拿到uuid后去查询redis,查询处理结果,如果为空说明业务还在处理(处理进度状态为执行中,并将状态返回,前台根据状态进行处理),如果不为空说明已经处理完成了(将json字符串转为对象,并返回)。
第二种方案就是异步处理业务,.