Acabei de receber este erro novamente hoje quando atualizei minha máquina (com atualizações para PHP) executando o Ubuntu 14.04 . O arquivo de configuração da distribuição /etc/php5/fpm/pool.d/www.conf
está bom e não requer nenhuma alteração atualmente.
Encontrei os seguintes erros:
dmesg | grep php
[...]
[ 4996.801789] traps: php5-fpm[23231] general protection ip:6c60d1 sp:7fff3f8c68f0 error:0 in php5-fpm[400000+800000]
[ 6788.335355] traps: php5-fpm[9069] general protection ip:6c5d81 sp:7fff98dd9a00 error:0 in php5-fpm[400000+7ff000]
O estranho é que eu tenho dois sites em execução que utilizam o PHP-FPM nesta máquina, um estava funcionando bem e o outro (uma instalação Tiny Tiny RSS) me deu um 502, onde ambos estavam funcionando bem antes .
Comparei os dois arquivos de configuração e descobri que fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
estava faltando no site afetado.
Os dois arquivos de configuração agora contêm o seguinte bloco e estão funcionando corretamente novamente:
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
include /etc/nginx/snippets/fastcgi-php.conf;
}
Atualizar
Deve-se notar que o Ubuntu envia dois arquivos de parâmetros relacionados ao fastcgi e também um trecho de configuração que está disponível desde o Vivid e também na versão PPA . A solução foi atualizada de acordo.
Diferença dos arquivos de parâmetro fastcgi:
$ diff -up fastcgi_params fastcgi.conf
--- fastcgi_params 2015-07-22 01:42:39.000000000 +0200
+++ fastcgi.conf 2015-07-22 01:42:39.000000000 +0200
@@ -1,4 +1,5 @@
+fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param CONTENT_TYPE $content_type;
Snippet de configuração em /etc/nginx/snippets/fastcgi-php.conf
# regex to split $uri to $fastcgi_script_name and $fastcgi_path
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# Check that the PHP script exists before passing it
try_files $fastcgi_script_name =404;
# Bypass the fact that try_files resets $fastcgi_path_info
# see: http://trac.nginx.org/nginx/ticket/321
set $path_info $fastcgi_path_info;
fastcgi_param PATH_INFO $path_info;
fastcgi_index index.php;
include fastcgi.conf;