技术解析

请教 nginx log_by_lua 过滤请求方法
0
2021-05-19 23:32:40
idczone

RT,我们的日志时用 cloudflare 开源的一个工具来收集的, https://github.com/cloudflare/lua-resty-logger-socket/ 但最近看日志的时候发现收集了很多心跳检测的数据,感觉这些没什么用,浪费磁盘空间,所以想屏蔽掉这些数据的收集,看了一下, 这类健康检测的收集大部分请求方法都是 head, 所以想过滤一下,但是完全不懂 lua 脚本,只能来请教 v2 诸位大神了

lua 大概内容如下

if uri=='/api/global_visit_log_v2.php' then
  ngx.exit(200)
end
t['host']               = ngx.var.hostname or "-"
t['server_name']        = ngx.var.server_name or "-"
t['uri']                = uri or "-"
t['args']               = ngx.var.args or "-"
t['body_bytes_sent']    = ngx.var.body_bytes_sent or 0
t['status']             = ngx.var.status or ""
t['referer']            = ngx.var.http_referer or "-"
t['user_agent']         = ngx.var.http_user_agent or "-"
t['real_ip']            = real_ip
t['response_time']      = ngx.var.upstream_response_time or 0
t['logtime']            = ngx.time()

我可以直接这样写么 if request_method=='head' then 美国服务器ngx.exit(200)

还有,下面定义的这些变量是从 ngx 的请求体拿的么, ngx.var 是啥意思


居然没人,伤心

[OpenResty 最佳实践]( https://moonbingbing.gitbooks.io/openresty-best-practices/content/index.html)

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服