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 的访问日志里就排除的这些访问量特别大又没啥信息量的项,避免日志过大。

热门相关:我的治愈系游戏   道君   锦乡里   天神诀   贪图兄长