通过CLI的PHP成功地将错误记录到/var/log/php_errors.log。
但apache + php不记录错误。
[bla@notebook ~]$ apachectl -v
Server version: Apache/2.2.17 (Unix)
Server built: May 19 2011 03:15:39
[bla@notebook ~]$ php -v
PHP 5.3.6 with Suhosin-Patch (cli) (built: Mar 23 2011 13:28:00)
Copyright (c) 1997-2011 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2011 Zend Technologies
在php.ini中我有:
display_errors = On
error_reporting = E_ALL | E_STRICT
log_errors = On
error_log = php_errors.log
在httpd.conf:
ErrorLog "/var/log/httpd/error_log"
权限:
[bla@notebook /]$ ls -la /var/log/httpd/
-rwxrwxr-x 1 root root 133351 21.11.2011 11:18 access_log*
-rwxrwxr-x 1 root http 1307 21.11.2011 11:18 error_log*
[bla@notebook /]$ ls -la /var/log/php_errors.log
-rwxrwxr-x 1 root http 521 14.11.2011 17:31 /var/log/php_errors.log*
正如你所看到的,Apache守护进程有权写入日志文件。
在/var/log/php_errors.log和/ var / log / httpd / error_log中仍然没有来自Apache或PHP的错误。
更新1。
在php.ini中更改了这一行:
error_log = php_errors.log
要达到完全路径:
error_log = /var/log/php_errors.log
可以调试logfile 0777的设置权限或更改文件所有者。
发布于 2018-03-02 08:59:31
Apache和CLI通常有两个单独的php.ini文件 - 你确定你正在查看正确的文件吗?
我能想到的另外两个选项:
http
用户组中的用户有足够的权限写入日志文件 - 可能会出现类似suphp的行为,并且当通过网络访问您的脚本时,将使用/作为用户名进行设置所有者(该脚本的文件所有者) - 尝试更改它。发布于 2018-03-02 10:10:21
我有同样的问题。
设置log_errors_max_len = 0
在php.ini为我工作。
设置log_errors的最大长度(以字节为单位)。在error_log中添加关于源的信息。默认值是1024,0不允许应用任何最大长度。这个长度适用于记录错误,显示错误,也适用于$ php_errormsg,但不适用于显式调用函数,如error_log()。
https://stackoverflow.com/questions/-100004183
复制相似问题