nginx访问日志过滤(多条件)
nginx的access_log的过滤网上有很多文章。是通过map定义一个变量,然后把那个变量配置到access_log的if即可。
比如:
map $status $loggable { ~^[23] 0; default 1; } access_log /path/to/access.log combined if=$loggable;
定义一个变量loggable,http状态码是2XX、3XX的返回0,其他情况返回1。然后access_log当loggable为0时就不记录。
但是我现在有两条件,一个是固定url,一个是负载均衡的心跳检测。
对于组合条件,这里的if不支持运算。
最后是在mpa定义变量时default用上一个变量的值解决的。配置如下:
map $http_user_agent $health { default 1; ELB-HealthChecker/2.0 0; } map $uri $loggable { default $health; ~^/spicalURI* 0; } access_log /var/log/nginx/access.log main if=$loggable;
定义$loggable时用 default $health 达到了“或”的效果。
这样nginx 的访问日志里就排除的这些访问量特别大又没啥信息量的项,避免日志过大。