Estoy tratando de averiguar a dónde van los errores de PHP en mi configuración. Estoy ejecutando nginx como el proxy inverso para PHP-FPM, pero no veo los diversos mensajes E_NOTICE o E_WARNING que mi aplicación está produciendo. La única razón por la que sé que están sucediendo es por respuestas fallidas y trazas de pila de captura de NewRelic.
Aquí está la configuración de registro:
nginx.conf
proxy_intercept_errors on;
fastcgi_intercept_errors on;
php.ini
error_reporting = E_ALL
display_errors = Off
display_startup_errors = Off
log_errors = On
log_errors_max_len = 1024
ignore_repeated_errors = Off
ignore_repeated_source = Off
report_memleaks = On
track_errors = On
error_log = syslog
php-fpm.conf
[global]
error_log = /var/log/php-fpm/fpm-error.log
[www]
access.log = /var/log/php-fpm/access.log
access.format = "%t \"%m %r%Q%q\" %s %{mili}dms %{kilo}Mkb %C%%"
catch_workers_output = yes
php_flag[display_errors] = on
php_admin_flag[log_errors] = true
rsyslog.conf
:syslogtag, contains, "php" /var/log/php-fpm/error.log
He configurado PHP para iniciar sesión en syslog, sin embargo, FPM no tiene la función syslog, por lo que está iniciando sesión en un archivo. Realmente no me importa dónde terminan los errores, solo que terminan en algún lugar.
¿Alguna pista sobre cómo podría hacer que esto funcione?