Corrigido substituindo location ~ \.
por location ~* ^.+.
O regex causou o problema.
Estou tentando desabilitar globalmente o access_log e log_not_found em todo o conteúdo estático e para todos os vhosts em execução na mesma instância do nginx.
Para gerenciar as configurações globais dentro do bloco {} do servidor, incluo um global/restrictions.conf
no bloco {} do servidor de cada vhost.
As configurações do vhost se parecem com:
server {
listen 1.2.3.4:80;
server_name domain.com *.domain.com;
access_log /var/domains/domain.com-access.log combined;
error_log /var/domains/domain.com-error.log error;
root /var/www/domain.com/;
location / {
index index.php index.html index.htm;
try_files $uri $uri/ @rewrites;
}
location @rewrites {
rewrite ^ /index.php last;
}
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/domain.com-php-fpm.socket;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include /etc/nginx/fastcgi_params;
}
# Include global restrictions config
include global/restrictions.conf;
}
O arquivo de configuração global para todos os vhosts em global / restrictions.conf se parece com:
# Global restrictions configuration file.
# Will be included in the server {] block of each vhost.
# Disable logging for robots.txt files <--- WORKS
location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}
# Disable logging for all static files <--- DOES NOT WORK (WHY??)
location ~ \.(atom|bmp|bz2|css|doc|docx|eot|exe|gif|gz|ico|jpeg|jpg|js|mid|midi|mp4|ogg|ogv|otf|png|ppt|rar|rss|rtf|svg|svgz|swf|tar|tgz|ttf|txt|wav|woff|xml|xls|xlsx|zip)$ {
log_not_found off;
access_log off;
}
A regra para o robots.txt parece funcionar bem em todos os vhosts, mas de alguma forma a regra com o regex para todos os outros arquivos estáticos não funcionará e eu não consigo descobrir o porquê.
Alguma ideia ou sugestão?
Corrigido substituindo location ~ \.
por location ~* ^.+.
O regex causou o problema.
Tags nginx virtualhost web-server