最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
nginx日志中添加请求的response日志
时间:2022-06-30 17:34:53 编辑:袖梨 来源:一聚教程网
由于此功能在nginx内置的功能中没有,需要安装第三方模块ngx_lua,由于此模块需要Lua语言,所以需要安装相应的Lua语言包
1. 下载安装LuaJIT
# cd /usr/local/src # wget http://luajit.org/download/LuaJIT-2.0.2.tar.gz # tar -xzvf LuaJIT-2.0.2.tar.gz # cd LuaJIT-2.0.2 # make
出现如下内容表示编译成功
OK Successfully built LuaJIT make[1]: Leaving directory `/usr/local/src/LuaJIT-2.0.2/src' ==== Successfully built LuaJIT 2.0.2 ==== # make install
出现如下内容,表示安装成功
==== Successfully installed LuaJIT 2.0.2 to /usr/local ====
2. 下载准备nginx lua模块
# cd /usr/local/src # wget https://github.com/chaoslawful/lua-nginx-module/archive/v0.8.6.tar.gz # tar -xzvf v0.8.6
3. 安装nginx
# cd /usr/local/src/ # wget http://nginx.org/download/nginx-1.4.2.tar.gz # tar -xzvf nginx-1.4.2.tar.gz # cd nginx-1.4.2 //先导入环境变量,告诉nginx去哪里找luajit # export LUAJIT_LIB=/usr/local/lib # export LUAJIT_INC=/usr/local/include/luajit-2.0 # ./configure --prefix=/usr/local/nginx-1.4.2 --add-module=../lua-nginx-module-0.8.6 # make -j2 # make install
4.测试安装是否成功
# cd /usr/local/nginx-1.4.2/conf/ # vi nginx.conf
lua指令方式
在server 中添加一个localtion
location /hello { default_type 'text/plain'; content_by_lua 'ngx.say("hello, lua")'; }
然后启动nginx
# cd /usr/local/nginx-1.4.2/sbin # ./nginx
浏览器访问:
显示:hello, lua
注意点:
1.注意每个模块的安装目录不能出现差错
2.如果之前通过apt-get方式安装了nginx,需要先删除nginx,因为此方式下载的软件无法编译
3.
到此说明第三方安装成功,
5.下面开始添加日志
http { log_format mylog 'response_body:$resp_body'; server { #记录nginx请求返回值 lua_need_request_body on; set $resp_body ""; body_filter_by_lua ' local resp_body = string.sub(ngx.arg[1], 1, 1000) ngx.ctx.buffered = (ngx.ctx.buffered or "") .. resp_body if ngx.arg[2] then ngx.var.resp_body = ngx.ctx.buffered end '; location / { proxy_pass http://127.0.0.1:5000; access_log /var/log/nginx/access.log mylog; } } }
到此便成功添加response日志。
如果懂Lua语言的,可以对如下代码进行修改,来更加符合自己的要求。
body_filter_by_lua ' local resp_body = string.sub(ngx.arg[1], 1, 1000) ngx.ctx.buffered = (ngx.ctx.buffered or "") .. resp_body if ngx.arg[2] then ngx.var.resp_body = ngx.ctx.buffered end ';
日志输出时,会发现语言响应结果涉及到字符汉字的时候转为16进制导致无法识别。
部分响应日志如下:
response_body: {x22codex22: 404, x22messagex22: x22xE8xAFxB7xE6xB1x82xE7x9Ax84xE8xB5x84xE6xBAx90xE4xB8x8DxE5xADx98xE5x9CxA8x22, x22datax22: {}}
可通过复制到python脚本进行解决。
str1=''' {x22codex22: 404, x22messagex22: x22xE8xAFxB7xE6xB1x82xE7x9Ax84xE8xB5x84xE6xBAx90xE4xB8x8DxE5xADx98xE5x9CxA8x22, x22datax22: {}} ''' print(str1.encode('raw_unicode_escape').decode('utf-8'))
输入结果为:
{"code": 404, "message": "请求的资源不存在", "data": {}}
相关文章
- 王者荣耀侦探能力大测试攻略 王者荣耀侦探能力大测试怎么过 11-22
- 无期迷途主线前瞻兑换码是什么 11-22
- 原神欧洛伦怎么培养 11-22
- 炉石传说网易云音乐联动怎么玩 11-22
- 永劫无间手游确幸转盘怎么样 11-22
- 无期迷途主线前瞻兑换码是什么 无期迷途主线前瞻直播兑换码介绍 11-22