技术解析
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 是啥意思