Je viens de recevoir à nouveau cette erreur aujourd'hui alors que je mettais à jour ma machine (avec des mises à jour pour PHP) exécutant Ubuntu 14.04 . Le fichier de configuration de distribution /etc/php5/fpm/pool.d/www.conf
est correct et ne nécessite aucune modification actuellement.
J'ai trouvé les erreurs suivantes:
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 chose étrange était que j'ai 2 sites en cours d'exécution qui utilisent PHP-FPM sur cette machine, l'un fonctionnait bien et l'autre (une installation Tiny Tiny RSS) m'a donné un 502, où les deux fonctionnaient bien auparavant .
J'ai comparé les deux fichiers de configuration et j'ai constaté qu'il fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
manquait pour le site affecté.
Les deux fichiers de configuration contiennent désormais le bloc suivant et fonctionnent à nouveau correctement:
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
include /etc/nginx/snippets/fastcgi-php.conf;
}
Mettre à jour
Il convient de noter qu'Ubuntu expédie deux fichiers de paramètres liés à fastcgi et également un extrait de configuration qui est disponible depuis Vivid et également dans le PPA version . La solution a été mise à jour en conséquence.
Diff des fichiers de paramètres 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;
Extrait de configuration dans /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;