在运行Apache和PHP 5的一台Linux服务器上,我们有多个具有单独日志文件的虚拟主机。我们似乎无法在虚拟主机之间分离php error_log
。
覆盖<Location>
的httpd.conf
中的这个设置似乎没有做任何事情。
有没有办法为每个虚拟主机分别使用php error_logs
?
要设置Apache(而不是PHP)日志,最简单的方法是:
<VirtualHost IP:Port>
# Stuff,
# More Stuff,
ErrorLog /path/where/you/want/the/error.log
</VirtualHost>
如果没有前导“/”,则认为它是相对的。
你可以尝试:
<VirtualHost myvhost:80>
php_value error_log "/var/log/httpd/vhost_php_error_log"
</Virtual Host>
但我不确定是否会起作用。我尝试在我的网站上没有成功。
创建简单的VirtualHost:
示例主机名: - thecontrolist.localhost
127.0.0.1 thecontrolist.localhost
在hosts文件中<VirtualHost *>
ServerName thecontrolist.localhost
ServerAlias thecontrolist.localhost
DocumentRoot "/xampp/htdocs/thecontrolist"
<Directory "/xampp/htdocs/thecontrolist">
Options +Indexes +Includes +FollowSymLinks +MultiViews
AllowOverride All
Require local
</Directory>
</VirtualHost>
如果有人来看它应该是这样的:
<VirtualHost *:80>
ServerName example.com
DocumentRoot /var/www/domains/example.com/html
ErrorLog /var/www/domains/example.com/apache.error.log
CustomLog /var/www/domains/example.com/apache.access.log common
php_flag log_errors on
php_flag display_errors on
php_value error_reporting 2147483647
php_value error_log /var/www/domains/example.com/php.error.log
</VirtualHost>
这是为了开发,因为display_error
开启。您会注意到Apache错误日志与PHP错误日志是分开的。好消息是在php.error.log
。
看看这里的error_reporting
关键http://www.php.net/manual/en/errorfunc.configuration.php#ini.error-reporting
我通常只是在.htaccess
文件或我正在处理的域上的vhost.conf
中指定它。将其添加到以下文件之一:
php_admin_value error_log "/var/www/vhosts/example.com/error_log"
默认行为是error_log()输出到Apache错误日志。如果没有发生这种情况,请检查error_log指令的php.ini设置 - 保持未设置状态以使用当前vhost的Apache日志文件。
不要将error_log
设置为你的syslog
所在的地方,eg /var/log/apache2
,因为他们的错误将被ErrorLog
拦截。相反,在项目文件夹中为日志创建一个subdir
并执行php_value
error_log "/path/to/project/logs"
。这适用于.htaccess
文件和vhosts。还要确保你把php_flag
log_errors
打开
您是否尝试将php_value error_log '/path/to/php_error_log
添加到VirtualHost配置中?
是的,你可以试试,
php_value error_log "/var/log/php_log"
在.htaccess
中,如果他们想要记录,你可以让用户在他们的脚本开头使用ini_set()
。
另一种选择是使脚本默认使用脚本在文件夹中的php.ini
,然后转到用户/主机的根文件夹,然后转到服务器的根目录或类似的东西。这将允许主机添加自己的php.ini
值和他们自己的error_log
位置。
php_value error_log "/var/log/httpd/vhost_php_error_log"
它适用于我,但我必须更改日志文件的权限。
或Apache将日志写入其error_log
。
我的Apache在httpd.conf中有这样的东西。只需更改ErrorLog和CustomLog设置即可
<VirtualHost myvhost:80>
ServerAdmin [email protected]
DocumentRoot /opt/web
ServerName myvhost
ErrorLog logs/myvhost-error_log
CustomLog logs/myvhost-access_log common
</VirtualHost>