Nginx反向代理对后端服务器的容错处理

Nginx作为反向代理的时候,默认采用轮询方式,也就是一替一个的请求上游服务器。我们可以采用了ip_hash策略,使来自同一ip地址的人用同一台服务器响应。

如果上游服务器出现错误,比如404,500,等错误,上游服务器仍有一些服务是正常的,部服务不正常。这个时候Nginx并不会把上游服务器当做与故障来处理。

这时用户再次访问nginx的时候,经常出现404,500等错误。

解决方案

    location / {
        proxy_pass http://ssc_backend;
        ...
        proxy_next_upstream error timeout invalid_header http_500 http_404;
        proxy_connect_timeout   2;
   }

在代理上游服务器的的location配置块中,加上上面最后的两句话,或者直接使用
proxy_next_upstream error timeout invalid_header http_500 http_404;
这句话代表,如果Nginx向后端服务器请求的时候,如果出现了错误,超时,指定错误的响应码的时候,再请求上游下一个服务器。

如此可防止上游某服务器只提供部分服务。

个人觉得,在配置反向代理的时候建议加上这句话。

proxy_next_upstream error timeout invalid_header http_500 http_404;

参考

点赞