nginx日志解析

Nginx 的日志默认参数包括访问日志(Access Log)和错误日志(Error Log)。以下是对这些默认参数的详细解析:

1. 访问日志(Access Log)

访问日志记录了每个客户端请求的详细信息,包括请求的来源、时间、请求内容、响应状态码等。

默认访问日志位置

Nginx 默认会将访问日志记录到 /var/log/nginx/access.log

默认访问日志格式

Nginx 默认使用 combined 格式记录访问日志。combined 格式包括以下字段:

  • $remote_addr:客户端的 IP 地址。
  • $remote_user:客户端用户名(如果启用了基本认证)。
  • $time_local:本地时间,格式为 [day/month/year:hour:minute:second zone]
  • $request:请求行,包括请求方法、请求 URI 和协议版本。
  • $status:响应状态码。
  • $body_bytes_sent:发送给客户端的字节数(不包括响应头)。
  • $http_referer:请求的来源页面(Referer)。
  • $http_user_agent:客户端的用户代理(User-Agent)。
配置示例
nginx 复制代码
http {
    # 定义日志格式
    log_format combined '$remote_addr - $remote_user [$time_local] "$request" '
                        '$status $body_bytes_sent "$http_referer" '
                        '"$http_user_agent"';

    # 指定访问日志文件路径和使用的日志格式
    access_log /var/log/nginx/access.log combined;
}

2. 错误日志(Error Log)

错误日志记录了 Nginx 运行过程中发生的错误信息,包括启动错误、配置错误和请求处理错误等。

默认错误日志位置

Nginx 默认会将错误日志记录到 /var/log/nginx/error.log

默认错误日志级别

Nginx 默认的日志级别是 error,这意味着只记录 error 级别及以上级别(如 crit, alert, emerg)的日志。可以通过 error_log 指令修改日志级别。

配置示例
nginx 复制代码
http {
    # 指定错误日志文件路径和日志级别
    error_log /var/log/nginx/error.log error;
}

3. 其他常见日志级别

Nginx 支持以下日志级别:

  • debug:调试信息
  • info:普通信息
  • notice:通知信息
  • warn:警告信息
  • error:错误信息(默认)
  • crit:严重情况
  • alert:需要立即处理的情况
  • emerg:系统不可用

4. 完整示例配置

以下是一个完整的 Nginx 配置示例,包括访问日志和错误日志的默认参数配置:

nginx 复制代码
http {
    # 定义访问日志格式
    log_format combined '$remote_addr - $remote_user [$time_local] "$request" '
                        '$status $body_bytes_sent "$http_referer" '
                        '"$http_user_agent"';

    # 配置访问日志
    access_log /var/log/nginx/access.log combined;

    # 配置错误日志
    error_log /var/log/nginx/error.log error;

    server {
        listen 80;
        server_name example.com;

        location / {
            root /usr/share/nginx/html;
            index index.html index.htm;
        }
    }
}

5. 其他日志配置选项

Nginx 还支持其他一些日志配置选项,如:

  • 缓冲访问日志 :通过 access_log 指令中的 buffer 参数可以缓冲日志记录,提高性能。

    nginx 复制代码
    access_log /var/log/nginx/access.log combined buffer=32k;
  • 条件记录日志 :可以通过配置条件来有选择地记录日志。

    nginx 复制代码
    access_log /var/log/nginx/access.log combined if=$request_time > 1;
相关推荐
斗转星移34 小时前
Ubuntu20.04 中使用vscode中编辑查看PlantUML
linux·vscode·uml·plantuml
正经教主5 小时前
【问题】解决docker的方式安装n8n,找不到docker.n8n.io/n8nio/n8n:latest镜像的问题
运维·docker·容器·n8n
sukida1005 小时前
BIOS主板(非UEFI)安装fedora42的方法
linux·windows·fedora
●^●6 小时前
Linux 权限修改详解:chmod 命令与权限数字的秘密
linux
唯独失去了从容6 小时前
WebRTC服务器Coturn服务器中的通信协议
运维·服务器·webrtc
光而不耀@lgy7 小时前
C++初登门槛
linux·开发语言·网络·c++·后端
joker_zsl7 小时前
docker的安装和简单使用(ubuntu环境)
运维·docker·容器
偶尔微微一笑7 小时前
AI网络渗透kali应用(gptshell)
linux·人工智能·python·自然语言处理·编辑器
Run1.7 小时前
深入解析 Linux 中动静态库的加载机制:从原理到实践
linux·运维·服务器
VI8664956I267 小时前
全链路自动化AIGC内容工厂:构建企业级智能内容生产系统
运维·自动化·aigc