Como personalizar o LogFormat para hosts virtuais do Apache?

1

Eu realmente preciso de ajuda com isso. Meu servidor tem vários hosts virtuais, cada host virtual tem seu log de acesso, eu preciso ser capaz de personalizar o LogFormat para cada host virtual existente no servidor. Modifiquei o LogFormat em httpd.conf , mas ele afeta apenas o log de acesso principal e não os hosts virtuais.

Aqui está o meu LogFormat:

<IfModule log_config_module>
LogFormat "%v:%a %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %{CF-Connecting-IP}i" combinedvhost
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %{CF-Connecting-IP}i" combined
LogFormat "%h %l %u %t \"%r\" %>s %b %{CF-Connecting-IP}i" common

CustomLog "logs/access_log" combined
CustomLog logs/access_log combinedvhost

<IfModule logio_module>
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %{CF-Connecting-IP}i" combinedio
</IfModule>

</IfModule>

<IfModule mod_log_config.c>
LogFormat "%v:%a %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %{CF-Connecting-IP}i" combinedvhost
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %{CF-Connecting-IP}i" combined
LogFormat "%h %l %u %t \"%r\" %>s %b %{CF-Connecting-IP}i" common
LogFormat "%{Referer}i -> %U" referer
LogFormat "%{User-agent}i" agent

CustomLog logs/access_log common
CustomLog logs/access_log combined
CustomLog logs/access_log combinedvhost

</IfModule>

O LogFormat acima afeta apenas o log de acesso principal localizado em: /usr/local/apache/logs/access_log No entanto, ele não afeta nenhum dos hosts virtuais no servidor que têm seus logs de acesso localizados em: /home/username/access-logs/domain.com

Não tenho certeza se tenho algo errado no LogFormat em si ou se estiver faltando alguma coisa. Passei muitas horas tentando resolver esse problema, mas não encontrei uma solução. Eu agradeceria muito se alguém pudesse lançar alguma luz sobre isso. Obrigado.

    
por Mina Hafzalla 25.04.2015 / 02:55

2 respostas

2

O truque é adicionar diretivas CustomLog dentro de cada VirtualHost em seus arquivos de configuração do Apache. Por exemplo:

<VirtualHost *:80>
  ServerName www.site1.com
  DocumentRoot /var/www/www.site1.com/htdocs
  CustomLog /var/log/apache/www.site1.com-access.log combined
  ErrorLog /var/log/apache/www.site1.com-error.log
</VirtualHost>

<VirtualHost *:80>
  ServerName www.site2.com
  DocumentRoot /var/www/www.site2.com/htdocs
  CustomLog /var/log/apache/www.site2.com-access.log combined
  ErrorLog /var/log/apache/www.site2.com-error.log
</VirtualHost>

Existem exemplos mais úteis aqui .

    
por 25.04.2015 / 07:46
0

O truque é que você deve ter o LogFormat e o CustomLog no mesmo pool do VirtualHost


<VirtualHost *:443>
    ServerName my.site.com
    LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b %D  " commonvhost
    ErrorLog "|/opt/mw/apache-2.4.25-instance1/bin/rotatelogs /apps/logs/my.site.com-443-error.%Y.%m.%d.log 86400"
    CustomLog "|/opt/mw/apache-2.4.25-instance1/bin/rotatelogs /apps/logs/my.site.com-443-access.%Y.%m.%d.log 86400" commonvhost
</VirtualHost>

<VirtualHost *:80>
    ServerName my.site.com
    LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b %D  " commonvhost
    ErrorLog "|/opt/mw/apache-2.4.25-instance1/bin/rotatelogs /apps/logs/my.site.com-80-error.%Y.%m.%d.log 86400"
    CustomLog "|/opt/mw/apache-2.4.25-instance1/bin/rotatelogs /apps/logs/my.site.com-80-access.%Y.%m.%d.log 86400" commonvhost
</VirtualHost>
    
por 21.03.2018 / 21:36