2013年10月3日の午前10時50分まで断続的にクライアントに「502 Bad Gateway」エラーが返され始めるまで問題なく動作していたサーバーがあります。
5つのブラウザリクエストのうち約4つは成功しますが、約5つに1つは502で失敗します。
Nginxエラーログには、これらのエラーが何百も含まれています。
2013/10/05 06:28:17 [error] 3111#0: *54528 recv() failed (104: Connection reset by peer) while reading response header from upstream, client: 66.249.66.75, server: www.bec-components.co.uk request: ""GET /?_n=Fridgefreezer/Hotpoint/8591P;_i=x8078 HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", Host: "www.bec-components.co.uk"
ただし、PHPエラーログには、一致するエラーは含まれません。
PHPを取得する方法はありますか?接続がリセットされている理由の詳細を教えてください。
これは nginx.conf
;
user www-data;
worker_processes 4;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
access_log /var/log/nginx/access.log;
sendfile on;
keepalive_timeout 30;
tcp_nodelay on;
client_max_body_size 100m;
gzip on;
gzip_types text/plain application/xml text/javascript application/x-javascript text/css;
gzip_disable "MSIE [1-6]\.(?!.*SV1)";
include /gvol/sites/*/nginx.conf;
}
そして、これは.conf
このサイトの場合;
server {
server_name www.bec-components.co.uk bec3.uk.to bec4.uk.to bec.home;
root /gvol/sites/bec/www/;
index index.php index.html;
location ~ \.(js|css|png|jpg|jpeg|gif|ico)$ {
expires 2592000; # 30 days
log_not_found off;
}
## Trigger client to download instead of display '.xml' files.
location ~ \.xml$ {
add_header Content-disposition "attachment; filename=$1";
}
location ~ \.php$ {
fastcgi_read_timeout 3600;
include /etc/nginx/fastcgi_params;
keepalive_timeout 0;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
}
}
## bec-components.co.uk ##
server {
server_name bec-components.co.uk;
rewrite ^/(.*) http://www.bec-components.co.uk$1 permanent;
}
私のウェブサーバーが私に言っていれば、私は常に信頼します:502 Bad Gateway
どういう意味ですか:
fastcgiプロセスはnginxからアクセスできません。遅くなるか、まったく対応しなくなります。不適切なゲートウェイは、nginxが定義されたリソース127.0.0.1:9000にfastcgi_passできないことを意味します。 その特定の瞬間。
あなたの最初のエラーログはそれをすべて伝えます:
。
recv() failed
-> nginx failed
(104: Connection reset by peer) while reading response header from upstream,
-> no complete answer, or no answer at all
upstream: "fastcgi://127.0.0.1:9000",
-> who is he, who failed???
私の限られた視点から私がお勧めします:
私はこのトピックが古いことを知っていますが、それでも時々ポップアップし続けるので、Webで回答を探して、次の3つの可能性を思いつきました。
session.save_path = "/var/lib/php/sessions"
)。これは、不正なアクセス許可、不正な所有権、不正なユーザー/グループ、またはそのディレクトリ(またはディスク全体)でiノードが不足するなど、より難解な/不明瞭な問題である可能性があります。これは通常not多くのコアダンプを残し、おそらくPHPエラーログに何も記録しません。これも取得し続けました。使用する場合は、opcache
メモリ制限を増やすことで解決しました(APCの代替)。 PHP-FPMは、キャッシュがいっぱいになったときに接続をドロップしたようです。これは、shgnIncの回答がそれを短期間修正する理由でもあります。
したがって、ファイル/etc/php5/fpm/php.ini
(またはディストリビューションで同等のもの)を見つけ、memory_consumption
をサイトで必要なレベルまで増やします。 opcache
を無効にすることもできます。
[opcache]
opcache.memory_consumption = 196
Githubでこのgitを検討することをお勧めします: https://Gist.github.com/amichaelgrant/90d99d7d5d48bf8fd209
同様の状況に遭遇しました。上流サーバーのエラーログを確認したところ、いくつかのulimitエラーが報告されていたため、(上流ボックスとnginxボックスの両方で)1000000に増やし、すべてが正常に機能しました。
同じ問題が発生した場合は、php-fpm
サービスなので、解決しました。
Sudo service php5-fpm restart
または、この問題は大量のリクエストが原因で発生する場合もあります。デフォルトではpm.max_requests
php5-fpmの100以下かもしれません。
それを解決するためにその値を増加させることはあなたのサイトの要求、例えば500に依存します。
そして、あなたはサービスを再起動する必要があります後
私の場合、xdebug拡張を無効にすることで解決しました。
私にとっては、サーバーがメモリ不足になり、php-fpmがOOMキラーに殺されました。解決策は、サーバーのメモリ容量を増やすことでした。
私にとっては、php-fpmがmax_children
制限。問題のプールのphp-fpmログが正しい方向を示しています
私は同様の問題を抱えていました:
ポート9000でphp-fpmに接続します(fastcgi://127.0.0.1:9000)。
私のサーバー上のUbuntuの標準構成は次のとおりです。
/etc/php/7.0/fpm/pool.d/www.conf:
listen = /run/php/php7.0-fpm.sock
これを次のように変更する必要があります。
listen = 0.0.0.0:9000
私の場合、1か月前にサーバーを更新し、costom構成をデフォルトで上書きしました。現在、php-fpmを再起動しているため、このエラーは遅延して発生しました。
この問題は、PHP-FPMプロセスが割り当てられたメモリ制限を超えた場合にも発生する可能性があります。これが発生すると、NGINXとPHP-FPMの間の接続が切断され、NGINXは502 Bad Gateway
を返します。 PHP-FPMプロセスのメモリ制限は、memory_limit
変数によって制御されます。これは、PHP-FPM構成ファイルのphp_admin_value[memory_limit]
で設定できます。
メモリ制限はスクリプトごとに基づいて適用されることに注意することが重要です。 n
PHP-FPMプロセスでは、合計メモリ使用量は最大memory_limit * n
になる可能性があります。マシンに十分なメモリヘッドルームがあることを確認してください。