php错误日志不进apache error_log,需启用log_errors=on、正确配置error_log路径并确保权限,且error_reporting须覆盖错误级别;php-fpm环境下须在php.ini或pool配置中设置,而非apache指令。

PHP错误日志不进Apache error_log?检查php_flag log_errors是否启用
默认情况下,PHP错误(如E_WARNING、E_NOTICE)不会自动写入Apache的error_log,除非显式开启log_errors = On。在Apache配置中,这通常通过php_flag log_errors on实现,而不是靠display_errors(后者只控制页面输出,和日志无关)。
常见错误是只设了display_errors Off,却忘了开log_errors,结果错误既不显示也不记录。
- 必须在
<virtualhost></virtualhost>、<directory></directory>或.htaccess中设置:php_flag log_errors on - 若用PHP-FPM,该指令无效,应改在
php.ini或www.conf中配log_errors = On - Apache模块模式(mod_php)下,
php_flag仅对.htaccess或虚拟主机生效,主配置需用php_admin_flag
让PHP错误单独写入指定文件:用error_log指令指定路径
Apache本身不接管PHP错误的落盘路径,这个由PHP自己决定。关键配置项是error_log(注意不是Apache的ErrorLog指令),它控制PHP错误写到哪。
路径必须有Web服务器用户(如www-data或apache)的写权限,否则日志静默失败——这是最常被忽略的权限坑。
立即学习“PHP免费学习笔记(深入)”;
- 在
.htaccess中:php_value error_log "/var/log/php/myapp_error.log" - 在
VirtualHost中:php_admin_value error_log "/var/log/php/myapp_error.log" - 路径建议用绝对路径;相对路径会基于Apache工作目录(通常是
/或/var/www),极难调试 - 如果同时设置了
error_log和syslog,PHP优先走error_log文件
为什么error_log设了却没内容?排查error_reporting和log_errors联动
即使error_log路径正确、权限到位,仍可能无日志——因为PHP根本没“认为”该记。这取决于error_reporting值是否覆盖当前错误级别。
例如:代码触发E_DEPRECATED,但error_reporting设为E_ALL & ~E_DEPRECATED,那错误就不会进日志,哪怕log_errors=On。
- 推荐在生产环境统一用:
php_admin_value error_reporting "E_ALL & ~E_NOTICE & ~E_DEPRECATED"(按需调整) -
error_reporting可在运行时用error_reporting()函数修改,但php_admin_value在Apache配置中不可被覆盖 - 用
phpinfo()确认最终生效值,别只信配置文件里的注释行 - 注意:CLI模式下
error_log默认写到stderr,和Web环境完全隔离
Apache + PHP-FPM场景下,php_flag全失效:改用php.ini或pool.d配置
一旦用了PHP-FPM,Apache的php_flag/php_value指令全部被忽略。所有PHP配置必须下沉到PHP层:全局php.ini,或更推荐的——FPM Pool级配置(如/etc/php/*/fpm/pool.d/www.conf)。
这时error_log路径要写在FPM配置里,且支持动态变量,比如:php_admin_value[error_log] = /var/log/php/www-error-%y%m%d.log(支持%y%m%d等时间占位符)。
- FPM中
php_admin_value比php_value更安全,防止应用层覆盖 - 记得重启
php-fpm服务,而非Apache,配置才生效 - 日志轮转不能依赖Apache的
rotatelogs,得用logrotate或FPM内置的slowlog机制配合











