nginx做反向代理时,作为负载均衡器,对执行失败的任务默认会调度到其他节点执行。

默认设置:proxy_next_upstream error timeout #发生网络错误以及超时,才会在其他服务器重试

$ proxy_next_upstream error timeout http_500 #500时重试

$ proxy_next_upstream error timeout http_502 #502时重试

$ proxy_next_upstream error timeout http_503 #503时重试

需要特别注意的时,put,get类幂等方法重试是没有问题的。对于post方法是非幂等请求,默认针对post方法是不会重试的。比如创建订单请求,前端的超时,后端如果重试,可能会出现创建多个订单情况。如果非要开启post方法的重试(线上一般不会开启),加上non_idempotent参数。

$  proxy_next_upstream error timeout http_500 non_idempotent;#500重试,包括post,lock,path方法
 


发布评论
IT序号网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!

ls -lh文件大小比du -sh大知识解答
你是第一个吃螃蟹的人
发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。