温馨提示×

nginx日志格式自定义方法

小樊
48
2026-01-10 15:52:59
栏目: 编程语言

在Nginx中,您可以通过修改配置文件来自定义日志格式。以下是自定义日志格式的步骤:

  1. 打开Nginx配置文件。通常位于/etc/nginx/nginx.conf/etc/nginx/sites-available/your_domain.conf

  2. httpserverlocation块中,使用log_format指令定义一个新的日志格式。例如,创建一个名为custom_log_format的自定义日志格式:

http {
    ...
    log_format custom_log_format '$remote_addr - $remote_user [$time_local] '
                                  '"$request" $status $body_bytes_sent '
                                  '"$http_referer" "$http_user_agent" '
                                  '"$http_x_forwarded_for" "$request_time"';
    ...
}

在这个例子中,我们定义了一个包含以下字段的自定义日志格式:

  • $remote_addr:客户端IP地址
  • $remote_user:远程用户(如果已通过认证)
  • $time_local:本地时间,格式为[dd/MMM/yyyy:HH:mm:ss Z]
  • $request:请求行,包括HTTP方法、URL和HTTP版本
  • $status:HTTP响应状态码
  • $body_bytes_sent:发送给客户端的响应体字节数
  • $http_referer:引用页面的URL(如果有)
  • $http_user_agent:客户端浏览器的用户代理字符串
  • $http_x_forwarded_for:X-Forwarded-For头部的值(如果有)
  • $request_time:处理请求所花费的时间(秒)
  1. serverlocation块中,使用access_log指令指定要使用的自定义日志格式。例如,将自定义日志格式应用于名为example.com的虚拟主机:
server {
    ...
    access_log /var/log/nginx/example.com.access.log custom_log_format;
    ...
}
  1. 保存更改并重新加载Nginx配置以使更改生效。在命令行中运行以下命令:
sudo nginx -t      # 检查配置文件语法是否正确
sudo nginx -s reload  # 重新加载配置文件

现在,Nginx将使用您定义的自定义日志格式记录访问日志。

0