nginx日志配置

本文详细介绍了如何配置Nginx的日志,包括错误日志(error_log)的级别调整,访问日志(access_log)的格式设定与位置,条件日志记录的启用,日志文件缓存(open_log_file_cache)的优化,以及日志切割的两种方式:logrotate和shell脚本。通过这些设置,可以更好地管理和分析Nginx的日志。
摘要由CSDN通过智能技术生成

1. 配置错误日志 Error Log

Nginx 将遇到的不同严重级别问题的信息写入错误日志。 error_log 指令设置对特定文件,stderr 或 syslog 的日志记录,并指定要记录的消息的最低严重级别。 默认情况下,错误日志位于 logs/error.log(绝对路径取决于操作系统和安装),并且默认记录所有严重级别的消息。 
下面的配置将记录错误信息的最低级别从 error 改为 warn:

error_log  logs/error.log warn;

此时,warn、error crit、alert 和 emerg 这几种级别的消息会写入日志。

错误日志的默认设置在全局范围内有效。为了覆盖这个设置,可以在主配置文件的顶级上下文中使用 error_log 指令。主配置文件的顶级上下文中的设置可以被其他的配置上下文继承。error_log 还可以在 http、stream、server 和 location 上下文中制定,从而覆盖上层上下文中的设置。发生错误时,相关信息只会写入和错误最相关的上下文指定的那个错误日志。然而,如果在同一个上下文中使用了多个 error_log 指令,错误信息会写入所有指定的日志中。

2. 配置访问日志 Access Log

Nginx 会在客户端请求处理完成后,立刻把相关信息写入访问日志。默认情况下,访问日志位于 logs/access.log,并且信息会以预定义的组合格式写入日志。要覆盖默认设置,可以使用 log_format 指令更改日志消息的格式, access_log 指令指明日志位置和格式。日志格式用变量定义。

常见的日志变量

$remote_addr, $http_x_forwarded_for 记录客户端IP地址
$remote_user 记录客户端用户名称
$request 记录请求的URL和HTTP协议(GET,POST,DEL,等)
$status 记录请求状态
$body_bytes_sent 发送给客户端的字节数,不包括响应头的大小; 该变量与Apache模块mod_log_config里的“%B”参数兼容。
$bytes_sen
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值