婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > nginx日志中添加請求的response日志(推薦)

nginx日志中添加請求的response日志(推薦)

熱門標簽:機器人電銷有什么用 福州外呼系統中間件 威海人工智能電銷機器人系統 地圖標注員怎么去做 上海電銷卡外呼系統廠家 貴州全自動外呼系統廠家 德州外呼系統排名 好看的地圖標注圖標下載 百度地圖標注備注

由于此功能在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

瀏覽器訪問:

http://127.0.0.1/hello

顯示: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:    {\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腳本進行解決。

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日志,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

標簽:白城 岳陽 南陽 撫州 邵陽 南陽 葫蘆島 泉州

巨人網絡通訊聲明:本文標題《nginx日志中添加請求的response日志(推薦)》,本文關鍵詞  nginx,日志,中,添加,請求,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《nginx日志中添加請求的response日志(推薦)》相關的同類信息!
  • 本頁收集關于nginx日志中添加請求的response日志(推薦)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 沁阳市| 二手房| 琼海市| 万盛区| 深泽县| 即墨市| 河西区| 肥西县| 镇安县| 襄垣县| 札达县| 桦甸市| 湘潭市| 彩票| 麦盖提县| 北辰区| 阳春市| 中宁县| 九龙坡区| 犍为县| 安仁县| 日喀则市| 孝昌县| 杭锦旗| 年辖:市辖区| 商南县| 池州市| 宽甸| 沁阳市| 邮箱| 永定县| 乌鲁木齐市| 桃江县| 仪陇县| 会泽县| 敦煌市| 鞍山市| 新龙县| 蕉岭县| 招远市| 鲁山县|