Ho appena ricevuto di nuovo questo errore oggi mentre ho aggiornato la mia macchina (con aggiornamenti per PHP) con Ubuntu 14.04 . Il file di configurazione della distribuzione/etc/php5/fpm/pool.d/www.conf
va bene e al momento non richiede alcuna modifica.
Ho trovato i seguenti errori:
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]
La cosa strana è che ho 2 siti in esecuzione che utilizzano PHP-FPM su questa macchina uno funzionava bene e l'altro (un'installazione RSS Tiny Tiny) mi ha dato un 502, dove entrambi hanno funzionato bene prima .
Ho confrontato entrambi i file di configurazione e ho scoperto che fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
mancava per il sito interessato.
Entrambi i file di configurazione ora contengono il seguente blocco e funzionano di nuovo correttamente:
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
include /etc/nginx/snippets/fastcgi-php.conf;
}
Aggiornare
Va notato che Ubuntu spedisce due file di parametri relativi a fastcgi e anche uno snippet di configurazione che è disponibile da Vivid e anche nella versione PPA . La soluzione è stata aggiornata di conseguenza.
Diff dei file dei parametri 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 di configurazione in /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;