设置 access_log
access_log 语法
access_log path [format] [buffer=size] [gzip[=level]] [flush=time] [if=condition]; |
path
指定日志的存储路径format
指定日志的格式buffer
指定日志写入时的缓存大小gzip
日志写入前进行压缩,压缩比例 1 到 9 数值越大压缩率越高, 同时 cpu 消耗也越大, 默认为1flush
缓存的有效时间, 如果超过此时间, 缓存中的内容会被清空if
条件判断, 如果指定的条件不满足, 则不会写入日志
format 语法
Nginx 预定义了日志格式,如果没有明确指定日志格式默认使用该格式:
log_format main '$remote_addr - $remote_user [$time_local] ' |
如果不想使用 Nginx 预定义的格式,可以通过 format 指令来自定义。
下面是 format
指令中常用的一些变量:
变量 | 含义 |
---|---|
$bytes_sent | 发送给客户端的总字节数 |
$body_bytes_sent | 发送给客户端的字节数,不包括响应头的大小 |
$connection | 连接序列号 |
$connection_requests | 当前通过连接发出的请求数量 |
$msec | 日志写入时间,单位为秒,精度是毫秒 |
$pipe | 如果请求是通过http流水线发送,则其值为”p”,否则为“.” |
$request_length | 请求长度(包括请求行,请求头和请求体) |
$request_time | 请求处理时长,单位为秒,精度为毫秒,从读入客户端的第一个字节开始,直到把最后一个字符发送张客户端进行日志写入为止 |
$status | 响应状态码 |
$time_iso8601 | 标准格式的本地时间,形如“2017-05-24T18:31:27+08:00” |
$time_local | 通用日志格式下的本地时间,如”24/May/2017:18:31:27 +0800” |
$http_referer | 请求的referer地址 |
$http_user_agent | 客户端浏览器信息 |
$remote_addr | 客户端IP |
$http_x_forwarded_for | 当前端有代理服务器时,设置web节点记录客户端地址的配置,此参数生效的前提是代理服务器也要进行相关的x_forwarded_for设置 |
$request | 完整的原始请求行,如 “GET / HTTP/1.1” |
$remote_user | 客户端用户名称,仅针对启用了用户认证的请求 |
$request_uri | 完整的请求地址,如 “https://nginx.org“ |
测试
log_format main '$remote_addr $remote_user [$time_local] "$request" ' |
假如客户端有发起请求:https://example.com, 我们看一下一个请求的日志记录:
115.60.176.39 - [20/Apr/2022:22:06:20 +0800] "GET / HTTP/1.1" "https://example.com" 200 160 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/97.0.4692.71 Safari/537.36" "-" |
日志记录中 $remote_user
、$http_referer
、$http_x_forwarded_for
都对应了一个 -
,这是因为这几个变量为空。
设置 error_log
错误日志在 Nginx 中是通过 error_log
指令实现的。该指令记录服务器和请求处理过程中的错误信息。
语法
error_log file [level]; |
file
指定日志的写入位置level
指定错误级别, 可选值从低到高依次是debug
,info
,notice
,warn
,error
,crit
,alert
,emerg
只有设置日志的错误级别等于或高于level
指定的值才会写入错误日志中。默认值是error
基本用法
error_log /var/logs/nginx/error.log |
例子中指定了错误日志的路径为:/var/logs/nginx/error.log
, 日志级别使用默认的 error
总结
Nginx 中通过 access_log
和 error_log
指令配置访问日志和错误日志,通过 log_format
我们可以自定义日志格式。