nginx通过lua从日志中获得请求响应体

时间:2024-03-19 18:00:16

Nginx本身可以通过$request_body变量记录请求内容,但响应内容需要通过Lua模块记录:

步骤:
1 在nginx主配置文件nginx.conf日志格式中增加 $resp_body变量;
2 新增/usr/local/nginx/conf/resp_body.conf文件
nginx通过lua从日志中获得请求响应体

3 在server块中配置:
include /usr/local/nginx/conf/resp_body.conf;

总结: 此过程是在lua的body_filter_by_lua阶段

另外: lua处理有以下阶段:(7个)
1 set_by_lua 改写nginx变量,相当于set;
2 rewrite_by_lua 改写URI,可用于实现跳转/重定向;
3 access_by_lua 处理访问控制或限速;
4 content_by_lua 最常用的阶段,产生响应内容;
5 header_filter_by_lua 加工处理响应头,过滤数据;
6 body_filter_by_lua 加工处理响应体,可附加额外内容;
7 log_by_lua 记录日志,统计分析或其他收尾工作;

转载于:https://blog.51cto.com/wenxi123/2286682