位于 /server/nginx 的名为“off”的文件

位于 /server/nginx 的名为“off”的文件

/server/nginx 中有一个“off”文件。它记录错误日志。我在 nginx.conf 中将 error_log 设置为 /dev/null crit;。不明白为什么要创建这个“off”文件。我怎样才能阻止它记录日志。我的 nginx 版本是 1.16

以下是 nginx.conf:

user  www www;

worker_processes auto;

error_log  /dev/null crit;

pid        /www/server/nginx/logs/nginx.pid;

worker_rlimit_nofile 51200;

events
    {
        use epoll;
        worker_connections 51200;
        multi_accept on;
    }

http
    {
        include       mime.types;
        
        #include luawaf.conf;

        include proxy.conf;

        default_type  application/octet-stream;

        server_names_hash_bucket_size 512;
        client_header_buffer_size 32k;
        large_client_header_buffers 4 32k;
        client_max_body_size 200m;

        sendfile   on;
        tcp_nopush on;

        keepalive_timeout 60;

        tcp_nodelay on;

        fastcgi_connect_timeout 300;
        fastcgi_send_timeout 300;
        fastcgi_read_timeout 300;
        fastcgi_buffer_size 64k;
        fastcgi_buffers 4 64k;
        fastcgi_busy_buffers_size 128k;
        fastcgi_temp_file_write_size 256k;
        fastcgi_intercept_errors on;

        gzip on;
        gzip_min_length  1k;
        gzip_buffers     4 16k;
        gzip_http_version 1.1;
        gzip_comp_level 2;
        gzip_types     text/plain application/javascript application/x-javascript text/javascript text/css application/xml;
        gzip_vary on;
        gzip_proxied   expired no-cache no-store private auth;
        gzip_disable   "MSIE [1-6]\.";

        limit_conn_zone $binary_remote_addr zone=perip:10m;
        limit_conn_zone $server_name zone=perserver:10m;

        server_tokens off;
        access_log off;

server
    {
        listen 888;



        server_name phpmyadmin;
        index index.html index.htm index.php;
        root  /www/server/phpmyadmin;
            location ~ /tmp/ {
                return 403;
            }

        #error_page   404   /404.html;
        include enable-php.conf;
        include deny-bots.conf;

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
            error_log /dev/null;
            access_log off;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
            error_log /dev/null;
            access_log off;
        }

        location ~ /\.
        {
            deny all;
        }

        access_log  /www/wwwlogs/access.log;
    }
include /www/server/panel/vhost/nginx/*.conf;
}

答案1

这是因为所有access_log off条目。这不是有效的语法,它将其解释为名为off:)的文件

编辑:显然问题漏掉了一个流浪的error_log offoff是文件名。(仅)对于access_logoff显然可以将其关闭。

答案2

我找到了导致问题的原因。这是因为 /www/server/panel/vhost/nginx/ 处的 example.com.conf(nginx.conf 中的最后一行)。此 example.com.conf 中的位置部分添加了 error_log: off。

将 error_log: off 更改为 error_log /dev/null; “off” 文件中不会记录任何日志。停止 nginx,删除“off” 文件,然后启动 nginx。不会创建任何“off” 文件。

相关内容