У меня есть сервер, который работал нормально до 3 октября 2013 года в 10:50, когда он начал периодически возвращать ошибки «502 Bad Gateway» клиенту.
Приблизительно 4 из 5 запросов браузера выполняются успешно, но примерно 1 из 5 завершается с ошибкой 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;
}
PHP
скриптов. Я не используюphp-fpm
, я просто бегаюphp-fastcgi
, делаяphp-cgi -b 127.0.0.1:9000
. Работает без ошибок 3 года. Я не могу понять, почему он разработал эту проблему.php-cgi -b 127.0.0.1:9000
) периодически дает сбой, возможно, из-за увеличения трафика и нехватки ресурсов.Ответы:
я бы всегда доверял, если бы мои веб-серверы говорили мне:
502 Bad Gateway
что это означает:
ваш fastcgi-процесс не доступен nginx; либо замедлять, либо не соответствовать вообще. плохой шлюз означает: nginx не может fastcgi_pass к указанному ресурсу 127.0.0.1:9000; в этот особенный момент .
Ваши исходные журналы ошибок говорят обо всем:
,
из моего ограниченного POV я бы предложил:
источник
Gateway
в данном случае это сервер PHP. Спасибо.restart your fastcgi_process / server
это то, что помогло мне, спасибоЯ знаю, что эта тема старая, но она все еще иногда появляется, поэтому, ища ответы в Интернете, я нашел следующие три возможности:
session.save_path = "/var/lib/php/sessions"
. Это могут быть плохие разрешения, плохое владение, плохой пользователь / группа, или более эзотерические / неясные проблемы, такие как нехватка inode в этом каталоге (или даже полный диск!). Это обычно не оставляет много дампов ядра и, возможно, даже ничего в журналах ошибок PHP.источник
Продолжал получать это также. Решил это путем увеличения
opcache
лимита памяти, если вы его используете (замена на APC). Кажется, PHP-FPM сбрасывал соединения всякий раз, когда кеш переполнялся. Это также причина, по которой ответ shgnInc исправляет это на короткое время.Так что найдите файл
/etc/php5/fpm/php.ini
(или эквивалент в вашем дистрибутиве) и увеличьтеmemory_consumption
до того уровня, который нужен вашему сайту. Отключениеopcache
также может работать.источник
Вы можете рассмотреть этот git на github: https://gist.github.com/amichaelgrant/90d99d7d5d48bf8fd209
Я столкнулся с подобной ситуацией, когда я проверял журналы ошибок для моих вышестоящих серверов, они сообщали о некоторой ошибке ulimit, поэтому я увеличил ее до 1000000 (как на upstream, так и на nginx), и все работало нормально.
источник
В моем случае та же проблема, я просто перезапустить
php-fpm
службу, чтобы она решена.Или иногда эта проблема возникает из-за огромного количества запросов. По умолчанию
pm.max_requests
в php5-fpm может быть 100 или ниже.Чтобы решить его, увеличьте его стоимость в зависимости от запросов вашего сайта, например, 500.
И после вы должны перезапустить службу
источник
В моем случае отключение расширения xdebug помогло.
источник
У меня просто была похожая проблема:
Вы подключаетесь к php-fpm через порт 9000. (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
В моем случае я обновил свой сервер полтора месяца назад, перезаписав мою конфигурацию costom настройками по умолчанию. Теперь перезапустив php-fpm, эта ошибка вступила в силу с задержкой.
источник
Для меня это был сервер, исчерпавший память, и php-fpm был убит убийцей OOM. Решение было увеличить объем памяти сервера.
источник
Для меня это было потому, что php-fpm достигал
max_children
предела. Журнал php-fpm для рассматриваемого пула указал мне правильное направлениеисточник
Эта проблема может также возникнуть, если процесс PHP-FPM превышает предел выделенной памяти. Когда это происходит, соединение между NGINX и PHP-FPM разрывается, и NGINX возвращает a
502 Bad Gateway
. Ограничение памяти процесса PHP-FPM контролируетсяmemory_limit
переменной. Это можно установить сphp_admin_value[memory_limit]
помощью файла конфигурации PHP-FPM.Важно отметить, что ограничение памяти применяется для каждого сценария . С
n
процессами PHP-FPM общее использование памяти может быть доmemory_limit * n
. Убедитесь, что у вашей машины достаточно места для памяти!источник