今天看啥
    热点:

      北京赛车pk10历史记录 www.zwahn.com

      由于此功能在nginx内置的功能中没有,需要安装第三方??閚gx_lua,由于此??樾枰狶ua语言,所以需要安装相应的Lua语言包

      1. 下载安装LuaJIT

       
      1
      2
      3
      4
      5
      # cd /usr/local/src
      # tar -xzvf LuaJIT-2.0.2.tar.gz
      # cd LuaJIT-2.0.2
      # make

      出现如下内容表示编译成功

       
      1
      2
      3
      4
      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???/strong>

       
      1
      2
      3
      # cd /usr/local/src
      # tar -xzvf v0.8.6

      3. 安装nginx

       
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      # cd /usr/local/src/
      # 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.测试安装是否成功

       
      1
      2
      # cd /usr/local/nginx-1.4.2/conf/
      # vi nginx.conf

      lua指令方式

      在server 中添加一个localtion

       
      1
      2
      3
      4
      location /hello {
         default_type 'text/plain';
         content_by_lua 'ngx.say("hello, lua")';
        }

      然后启动nginx

       
      1
      2
      # cd /usr/local/nginx-1.4.2/sbin
      # ./nginx

      浏览器访问:

      //127.0.0.1/hello

      显示:hello, lua

      注意点:

      1.注意每个??榈陌沧澳柯疾荒艹鱿植畲?/p>

      2.如果之前通过apt-get方式安装了nginx,需要先删除nginx,因为此方式下载的软件无法编译

      3.

      到此说明第三方安装成功,

      5.下面开始添加日志

       
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      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语言的,可以对如下代码进行修改,来更加符合自己的要求。

       
      1
      2
      3
      4
      5
      6
      7
      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:    {\x22code\x22: 404, \x22message\x22: \x22\xE8\xAF\xB7\xE6\xB1\x82\xE7\x9A\x84\xE8\xB5\x84\xE6\xBA\x90\xE4\xB8\x8D\xE5\xAD\x98\xE5\x9C\xA8\x22, \x22data\x22: {}}

      可通过复制到python脚本进行解决。

       
      1
      2
      3
      4
      str1='''
      {\x22code\x22: 404, \x22message\x22: \x22\xE8\xAF\xB7\xE6\xB1\x82\xE7\x9A\x84\xE8\xB5\x84\xE6\xBA\x90\xE4\xB8\x8D\xE5\xAD\x98\xE5\x9C\xA8\x22, \x22data\x22: {}}
      '''
      print(str1.encode('raw_unicode_escape').decode('utf-8'))

      输入结果为:

      {"code": 404, "message": "请求的资源不存在", "data": {}}

      总结

      以上所述是小编给大家介绍的nginx日志中添加请求的response日志,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

      北京赛车pk10历史记录 www.zwahn.comtrue//www.zwahn.com/Nginxjc/1316497.htmlTechArticle由于此功能在nginx内置的功能中没有,需要安装第三方??閚gx_lua,由于此??樾枰狶ua语言,所以需要安装相应的Lua语言包 1. 下载安装LuaJI...

      相关文章

        暂无相关文章
      相关搜索:

      帮客评论

      视觉看点