で、それをバックエンドにしてさらにNginxでロードシェアする時の設定。
data:image/s3,"s3://crabby-images/fcf24/fcf244e627e49b1030e56275df48a0c9243d2171" alt="画像:nginx-nginx-unicorn_01 画像:nginx-nginx-unicorn_01"
バックエンドのunicornが健在の時はフロント<=>バック間のレスポンスは上図のようになり、適当にロードシェアされます。
nginxのデフォルト設定ではバックエンドがunicornの状態に応じて502を返す際にも、フロントは気にしません。
data:image/s3,"s3://crabby-images/5d823/5d8234afb327765a44ebb4e1092707abbf9bd278" alt="画像:nginx-nginx-unicorn_02 画像:nginx-nginx-unicorn_02"
上図の状態になってもupstream対象を調整せずに、200, 502, 200, 502 とレスポンスを返します。
そりゃ困るということでドキュメントを参照、 HttpProxyModuleのproxy_next_upstream を使ってupstreamのポリシーを指定すればOKです。
デフォルトだとこうなっているので、
"proxy_next_upstream error timeout;"
http_502 を足してあげれば502を回避するようになります。
"proxy_next_upstream error timeout http_502 http_503;"
0 件のコメント:
コメントを投稿