「Nginx」- 在日志路径中,使用变量 @20210217

access_log (ngx_http_log_module)

在 access_log 中,使用变量:

access_log /home/me/sites/${server_name}.access.log;

但是,需要从(0.7.6+)以后,并且存在限制(参考「access_log」手册):
1)日志文件用“工作进程”创建,所以需要在日志目录有创建文件的权限。
2)无法使用写入缓冲。
3)由于经常使用的文件描述符会被缓存,在指令 open_log_file_cache 的参数 valid 指定的时间内,还会写入旧文件中。
4)每次写入日志时,会检查 root 目录是否存在。不存在,则不会创建日志。

error_log (ngx_core_module)

对于 error_log 属性,官方手册的「error_log」上没提可以使用变量。

# 07/10/2019 Nginx error log won't read variable - 不支持
# 07/10/2019 #562 closed enhancement (invalid) - 不支持

根据官方的说法:
1)这是故意这个设计的。变量只在 HTTP 请求中可用,而 error_log 不限于HTTP请求。
2)错误日志是非常重要的。必须保证可用。例如,当解析 /path/$var/error.log$var 变量出错(比如内存分配)时,应该在哪里记录错误日志呢?
3)可以考虑在非 main 块以外的上下文中支持变量。

我们的方案

对于这两个日志文件,我们直接进行硬编码(因为,一个不好,一个不行)。在 Nginx variable expansion in error_log for virtual hosts/servers 中,作者也解释了,这没什么必要。

如果想要使用这种方式,建议进行性能测试,评估没有写入缓存经常打开和关闭文件等等这些限制对性能的影响。

相关文章

「Nginx」- 记录 HTTP 请求头到日志
「Nginx」- 自定义日志格式

参考文献

Module ngx_http_log_module/access_log
Module ngx_http_log_module/open_log_file_cache
Variables in log name - nginx
Core functionality/error_log
Nginx error log won't read variable
#562 closed enhancement (invalid)
Nginx variable expansion in error_log for virtual hosts/servers

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值