• 黔江:1000余亩蓝莓成熟 市民乐享“莓”好时光 2019-05-22
  • 【周展安】重新认识《在延安文艺座谈会上的讲话》的现实意义 2019-05-22
  • 十九大代表卢丽安利用周末与在沪台胞分享她参会心得  2019-05-19
  • (两会受权发布)最高人民法院院长简历 2019-05-14
  • 巫山县大峡村:深度贫困村的脱贫之变 2019-05-12
  • “关注泌尿健康”三金片媒体沙龙北京站 2019-05-09
  • 人民网评:教师欠薪为何又成新闻了? 2019-05-07
  • 涪陵:全国人大代表刘家奇院坝讲“两会” 乡亲点赞“六子致富经” 2019-05-07
  • 海南将与香港携手开拓国际客源市场--旅游频道 2019-05-01
  • 赵孟頫:书法大师是怎么炼成的? 2019-04-28
  • 只看到“贫穷”而看不到“富裕”,只看到贫富差别而看不到其根源是社会财富被个人占为私有的私有制,都是片面错误的。 2019-04-25
  • 紫光阁中共中央国家机关工作委员会 2019-04-25
  • 大众因“排放门”被罚10亿欧元 外媒:处罚还没完 2019-04-11
  • 俄罗斯足球队50横扫沙特队真是让人大饱眼福,特提精神!俄罗斯是战斗民族名不虚传。 2019-04-09
  • 西安启动唐长安城明德门遗址保护工程 2019-04-07
  • 今天看啥
      热点:

        新疆35选7的开奖号 www.ts3ne.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日志,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

        新疆35选7的开奖号 www.ts3ne.comtrue//www.ts3ne.com/Nginxjc/1316497.htmlTechArticle由于此功能在nginx内置的功能中没有,需要安装第三方??閚gx_lua,由于此??樾枰狶ua语言,所以需要安装相应的Lua语言包 1. 下载安装LuaJI...

        相关文章

          暂无相关文章
        相关搜索:

        帮客评论

        视觉看点
      • 黔江:1000余亩蓝莓成熟 市民乐享“莓”好时光 2019-05-22
      • 【周展安】重新认识《在延安文艺座谈会上的讲话》的现实意义 2019-05-22
      • 十九大代表卢丽安利用周末与在沪台胞分享她参会心得  2019-05-19
      • (两会受权发布)最高人民法院院长简历 2019-05-14
      • 巫山县大峡村:深度贫困村的脱贫之变 2019-05-12
      • “关注泌尿健康”三金片媒体沙龙北京站 2019-05-09
      • 人民网评:教师欠薪为何又成新闻了? 2019-05-07
      • 涪陵:全国人大代表刘家奇院坝讲“两会” 乡亲点赞“六子致富经” 2019-05-07
      • 海南将与香港携手开拓国际客源市场--旅游频道 2019-05-01
      • 赵孟頫:书法大师是怎么炼成的? 2019-04-28
      • 只看到“贫穷”而看不到“富裕”,只看到贫富差别而看不到其根源是社会财富被个人占为私有的私有制,都是片面错误的。 2019-04-25
      • 紫光阁中共中央国家机关工作委员会 2019-04-25
      • 大众因“排放门”被罚10亿欧元 外媒:处罚还没完 2019-04-11
      • 俄罗斯足球队50横扫沙特队真是让人大饱眼福,特提精神!俄罗斯是战斗民族名不虚传。 2019-04-09
      • 西安启动唐长安城明德门遗址保护工程 2019-04-07