我正在尝试为 apache2 制作通配符 VirtualHost conf 文件,但我不确定如何处理ErrorLog
和CustomLog
设置以将日志放在我希望它们去的地方。正如您在第二个中看到的那样VirtualHost
,我将日志放在logs
域中的一个文件夹中DocumentRoot
。这适用于 static VirtualHost
,但我将如何处理通配符VirtualHost
。例如,第一个VirtualHost
.
NameVirtualHost *:80
# Wild card all subdomains
<VirtualHost *:80>
ServerAlias *.example.com
VirtualDocumentRoot /var/www/%0/public
ErrorLog ?????
CustomLog ????? combined
</VirtualHost>
# Main domain
<VirtualHost *:80>
ServerName example.com
ServerAlias www.example.com
DocumentRoot /var/www/example.com/public
ErrorLog /var/www/example.com/logs/error.log
CustomLog /var/www/example.com/logs/access.log combined
</VirtualHost>
我已经尝试过ErrorLog /var/www/*.example.com/logs/error.log
,ErrorLog /var/www/%0/logs/error.log
并且相同CustomLog
,但是当我尝试重新启动 apache 时,它会引发错误。
我应该使用什么语法来获得ErrorLog
上面示例的工作版本?
我在带有动态日志的虚拟主机中看到了通配符?,但这并不是我真正想要的,因为它仍然最终将所有日志放入一个大文件中,而不是将它们拆分到自己的子域特定文件夹中。
冒着给您更多工作的风险,您可能还想考虑采取相反的方向并将所有日志文件合并到
syslog
. 这似乎更令人生畏,但它是一个更有能力的解决方案。我根本不再关心单独的日志,只需将所有日志直接通过管道传输到系统日志(它将所有内容保存在 /var/log/messages 中)。尽管 Apache 本身并没有这样做,但您可以像这样实现它......
Syslog 将为您提供很多选项,因为设置了大量的服务和实用程序来解析和管理它。我
lnav
个人喜欢使用,您可以过滤、排序、搜索等,并且 ssh 上的界面是彩色的,因此很容易发现问题。您还可以使用实用程序将所有这些交付到一个没有限制的 SQL 数据库中,或者为了减少工作量,您可以使用具有漂亮仪表板的商业服务,如datadog :)。您需要阅读设施(
local1-7
在上面的定义中,我将我的访问日志和错误日志都传送到
logger
该实用程序中,该实用程序旨在接受日志并在 syslog 中以通用格式记录它们以及提供它们的服务的详细信息。您可以看到这%v
是我的访问日志的第一部分,它可以轻松过滤 syslog 中的虚拟主机。您会在指令中注意到,错误日志使用
local6.err
而访问日志使用local6.notice
,这实际上设置了日志行的级别,错误最终将在 中涂成红色lnav
,而其他错误将是标准/信息。当心兔子洞;)
一种解决方案是在事后拆分组合日志。Apache 有一个名为
split-logfile
( https://httpd.apache.org/docs/2.4/programs/split-logfile.html )的实用程序从文档...
创建一个包含虚拟主机信息的日志文件:
将在您运行脚本的目录中为组合日志文件中出现的每个虚拟主机名创建日志文件。这些日志文件将以主机名命名,文件扩展名为 .log。
从标准输入读取组合的日志文件。读取的记录将附加到任何现有的日志文件中。