访问日志
nginx在处理请求后立即在访问日志中写入有关客户端请求的信息。默认情况下,访问日志位logs/access.log中,信息以预定义的组合格式写入日志。
想要精确记录访问信息,就需要自定义一个更加完整的访问日志格式,如下所示:
'[$time_local]$remote_addr'
'$realip_remote_addr$remote_user'
'$request_method$server_protocol'
'$scheme$server_name$uri$status'
'$request_time$body_bytes_sent'
'$geoip_city_country_code3$geoip_region'
'"$geoip_city"$http_x_forwarded_for'
'$upstream_status$upstream_response_time'
'"$http_referer""$http_user_agent"';
}
如果需要使用这个日志配置,需要结合使用access_log指令,access_log指令接收一个日志目录和使用的配置名作为参数:
access_log/var/log/nginx/access.loggeoproxy;
}
access_log能在多个上下文使用,每个上下文中可以定义各自的日志目录和日志记录格式。
结论:nginx中的日志模块允许为不同的场景配置日志格式,以便查看不同的日志文件。
在实际运用中,为不同上下文配置不同的日志会非常有用,记录的日志内容可以简单的信息,也可以详细记录所有必要信息。不仅如此,日志内容除了支持文本
也能记录json格式和xml格式数据。实际上nginx日志有助于您了解服务器流量、客户端使用情况和客户端来源等信息。此外,访问日志还可以帮助您定位与上游服务器或特定uri相关的响应和问题;对于测试来讲,访问日志同样有用,它可以用于分析流量情况,模拟真实的用户交互场景。日志在故障排除、调试、应用分析及业务调整中作用是不可或缺的。
错误日志
为了精确定位nginx的错误日志,使用自带的error_log指令定义错误日志目录及记录错误日志的等级,配置如下:
error_log/var/log/nginx/error.logwarn;
除if指令外,error_log指令能在所有的上下文中使用。错误日志等级包括:
debug、info、notice、warn、error、crit、alert和emerg。给出的日志
等级顺序就是记录最小到最严谨的日志等级顺序。需要注意的是debug日志
需要在编译nginx服务器时,带上--with-debug标识才能使用。
当服务器配置出错时,首先需要查看错误日志以定位问题。错误日志
也是定位应用服务器(如fastcgi服务)的利器。通过错误日志,我们可以调试worker进程连接错误、内存分配、客户端ip和应用服务器等问题。错误日志格式不支持自定义日志格式;但他同样记录当前时间、日志等级和具体信息等数据。
注意:错误日志的默认设置适用于全局。要覆盖它,请将error_log指令放在main(顶级)配置上下文中。error_log在开源nginx1.5.2版中添加了在同一配置级别指定多个指令的功能。
通过syslog将日志发送到统一服务器
既然不再需要将日志写到磁盘的某个目录,而是发送到统一的日志服务器,则将原有的目录部分替换为服务器ip即可,配置如下:
error_logsyslog:server=10.0.1.42debug;
access_logsyslog:server=10.0.1.42,tag=nginx,severity=infogeoproxy;
#error_logserver=unix:/var/log/nginx.sockdebug;
#access_logsyslog:server=[2001:db8::1]:1234,facility=local7,tag=nginx,severity=info;
error_log和access_log指令的syslog参数紧跟冒号:和一些参数选项。包括:必选的server标记表示需要连接的ip、dns名称或unix套接字;
可以使用如上注释的高端玩。
可选参数有facility、severity、tag:
server参数接收带端口的ip地址或dns名称;默认是udp514端口。
facility参数设置syslog的类型facility,值是syslogrfc标准定义的23个值中一个,默认值为local7。其他可能的值是:auth,authpriv,daemon,cron,ftp,lpr,kern,mail,news,syslog,user,uucp,local0...local7
tag参数表示日志文件中显示时候的标题,默认值是nginx。
severity设置消息严重程度,默认是info级别日志。
日志缓冲区
当系统处于负载状态时,启用日志缓冲区以降低nginxworker进程阻塞。大量的磁盘读写和cpu资源使用对于服务器资源也是一种巨大消耗。将日志数据缓冲到内存中可能是很小的一个优化手段,buffer参数意义是缓冲区的大小,功能是当缓冲区已经写满时,日志会被写入文件中;flush参数意义是缓冲区内日志在缓冲区内存中保存的最长时间,功能即当缓存中的日志超过最大缓存时间,也会被写入到文件中,不足的地方即写入到日志文件的日志有些许延迟,即时调试中应当关闭日志缓冲。。配置如下:
access_log/var/log/nginx/access.logmainbuffer=32kflush=1m;
}
以上就是Nginx如何自定义记录及启用日志缓冲区的详细内容,更多请关注主机测评网其它相关文章!
本文来源:国外服务器--Nginx如何自定义记录及启用日志缓冲区(nginx自定义日志)
本文地址:https://www.idcbaba.com/guowai/4581.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 1919100645@qq.com 举报,一经查实,本站将立刻删除。



