码迷,mamicode.com
首页 > 其他好文 > 详细

error_reporting函数引起的error_log配置失效的问题

时间:2017-05-15 00:40:43      阅读:262      评论:0      收藏:0      [点我收藏+]

标签:进程   服务   cgi   stc   web服务   repo   php.ini   notice   nginx   

由于项目代码中大量使用了error_reporting(0);导致php.ini中的error_log失效,不记录错误日志,

导致调试起来非常不便,耗费大量的时间,所以在php.ini的配置中禁止掉error_reporting 函数!

 

nginx是一个web服务器,因此nginx的access日志只有对访问页面的记录,不会有php 的 error log信息。

nginx把对php的请求发给php-fpm fastcgi进程来处理,默认的php-fpm只会输出php-fpm的错误信息,在php-fpm的errors log里也看不到php的errorlog

原因是php-fpm的配置文件php-fpm.conf中默认是关闭worker进程的错误输出,直接把他们重定向到/dev/null,所以我们在nginx的error log 和php-fpm的errorlog都看不到php的错误日志。

调试起来就很痛苦了。解决nginx下php-fpm不记录php错误日志的办法:

1.修改php-fpm.conf中配置 没有则增加
catch_workers_output = yes
error_log = log/error_log

2.修改php.ini中配置,没有则增加
log_errors = On
error_log = "/usr/local/lnmp/php/var/log/error_log"
error_reporting=E_ALL&~E_NOTICE

3.重启php-fpm,
当PHP执行错误时就能看到错误日志在"/usr/local/lnmp/php/var/log/error_log"中了

 

error_reporting函数引起的error_log配置失效的问题

标签:进程   服务   cgi   stc   web服务   repo   php.ini   notice   nginx   

原文地址:http://www.cnblogs.com/dongruiha/p/6854455.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!