Estoy intentando configurar Nagios en NGiNX usando PHP-FPM.
Lo instalé fcgiwrap
y puedo ejecutar un script Perl desde la cgi-bin
carpeta, pero cuando intento acceder a Nagios, aparece el siguiente error en el registro de errores de NGiNX:
2012/08/23 16:40:21 [error] 8319#0: *1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 10.1.1.1, server: my.server.tld, request: "GET / HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "my.server.tld"
Recibí el mismo error al usar las ubicaciones predeterminadas, así que copié todo en diferentes carpetas para mantener intactos los archivos de instalación originales.
cp -R /usr/lib/cgi-bin/nagios3 /var/www/cgi-bin
cp -R /usr/share/nagios3/htdocs /var/www/html
Esto es lo que he puesto/etc/nginx/sites-available/default
server {
listen 80;
server_name my.domain.tld;
access_log /var/log/nginx/my.domain.tld.access.log;
error_log /var/log/nginx/my.domain.tld.error.log;
index index.php index.html index.htm;
location / {
root /var/www/html/;
auth_basic "Restricted";
auth_basic_user_file /etc/nagios3/.htpasswd-users;
}
# Pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \.php$ {
fastcgi_pass localhost:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
fastcgi_intercept_errors on;
}
# FastCGI Wrapper
location /cgi-bin/ {
gzip off;
root /var/www/;
fastcgi_pass unix:/var/run/fcgiwrap.socket;
include /etc/nginx/fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
Esto es lo que he puesto en mi/etc/nagios3/cgi.cfg
physical_html_path=/var/www/html
url_html_path=/
Esto es lo que estoy ejecutando, en cuanto a PHP:
PHP 5.3.16-1~dotdeb.0 with Suhosin-Patch (cli) (built: Aug 17 2012 22:03:18)
Copyright (c) 1997-2012 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2012 Zend Technologies
with the ionCube PHP Loader v4.2.2, Copyright (c) 2002-2012, by ionCube Ltd.
with Suhosin v0.9.33, Copyright (c) 2007-2012, by SektionEins GmbH
¿Alguna idea sobre qué causaría esto y/o cómo solucionarlo?
Respuesta1
Para aclararLa respuesta de ErikA:
esta diciendo"Se desconoce el guión principal"porqueNGiNXhacenosoporte para correrCGIdirectamente. Un programa de ayudadebeinstalarse para procesar elCGIarchivos y devolver la salida aNGiNX.
Por eso instalé fcgiwrap
, que procesa elCGIarchivos y pasa la salida aPHP-FPM, que luego es procesado porNGiNX,AFAIUI.
Aunque pensé que había empezado el init.d
guión de fcgiwrap
, no fue así.
Pude determinar esto ejecutando netstat -alnp | grep cgi
, que no arrojó ningún resultado hasta que comencé el script;/etc/init.d/fcgiwrap start
Después de iniciarlo, lo ejecuté netstat -alnp | grep cgi
nuevamente y obtuve el siguiente resultado:
unix 2 [ ACC ] STREAM LISTENING 18955 11251/fcgiwrap /var/run/fcgiwrap.socket
Una vez que el script se estaba ejecutando, yCGIestaba funcionando, ya no recibí este error yNagiostrabajó.
¡Bien por las migrañas que se atribuyen a pensamientos confusos y pequeños errores estúpidos!
Respuesta2
A menos que haya cambiado algo drástico en versiones recientes, Nagios no es una aplicación php.