ubuntu – 仅针对某些请求单独使用Nginx访问日志文件

前端之家收集整理的这篇文章主要介绍了ubuntu – 仅针对某些请求单独使用Nginx访问日志文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
据我所知,Nginx默认支持2个日志文件:error_log(跟踪与Nginx服务器本身相关的问题)和access_log(跟踪Nginx处理的请求).虽然可以使用 log_format指令控制access_log的格式,但我没有成功找到仅将某些请求记录到单独文件方法,因此我想将SF上的问题作为未来读者的参考:

有没有办法将某些请求记录到不同于access_log定义的日志文件

仅供参考,这个问题背后的原因是我有一条规则拒绝使用200访问不需要的爬虫(因为403会给他们一个暗示他们被阻止的提示),并且从access_log中过滤这些请求变得更加困难.

cjc让我走上正轨.在if语句中单独使用access_log是不可能的(你得到一个Nginx:[emerg]“access_log”指令不允许这里错误).所以解决方法如下:
if ($http_user_agent ~* (crawler) ) {
  set $crawler 'yes';
}
location ~ .* {
  if ($crawler = 'yes') {
    access_log /var/log/Nginx/blockedbots.log;
    return 200;
    }
}

猜你在找的Ubuntu相关文章