温馨提示×

nginx日志格式:如何自定义日志输出

小樊
42
2025-10-06 19:30:50
栏目: 编程语言

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

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

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

http { ... log_format my_custom_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:本地时间
  • $request:请求行(包括请求方法、URI 和 HTTP 版本)
  • $status:响应状态码
  • $body_bytes_sent:发送给客户端的响应体字节数
  • $http_referer:引用页面的 URL
  • $http_user_agent:客户端用户代理信息
  • $http_x_forwarded_for:X-Forwarded-For 请求头(如果存在)
  • $request_time:处理请求所花费的时间

你可以根据需要添加或删除字段。

  1. serverlocation 块中,使用 access_log 指令指定要使用的自定义日志格式。例如,将自定义日志格式应用于名为 my_domain.com 的站点:
http { ... server { listen 80; server_name my_domain.com; access_log /var/log/nginx/my_domain.com.access.log my_custom_format; ... } } 

在这个例子中,我们将自定义日志格式 my_custom_format 应用于名为 my_domain.com 的站点的访问日志,并将其存储在 /var/log/nginx/my_domain.com.access.log 文件中。

  1. 保存更改并重新加载 Nginx 配置以应用新的日志格式:
sudo nginx -t # 检查配置文件语法是否正确 sudo nginx -s reload # 重新加载配置文件 

现在,Nginx 将使用你定义的自定义日志格式输出日志。

0