由于此功能在nginx內(nèi)置的功能中沒有,需要安裝第三方模塊ngx_lua,由于此模塊需要Lua語言,所以需要安裝相應(yīng)的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
出現(xiàn)如下內(nèi)容表示編譯成功
OK Successfully built LuaJIT make[1]: Leaving directory `/usr/local/src/LuaJIT-2.0.2/src' ==== Successfully built LuaJIT 2.0.2 ==== # make install
出現(xiàn)如下內(nèi)容,表示安裝成功
==== Successfully installed LuaJIT 2.0.2 to /usr/local ====
2. 下載準(zhǔn)備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 //先導(dǎo)入環(huán)境變量,告訴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.測(cè)試安裝是否成功
# cd /usr/local/nginx-1.4.2/conf/ # vi nginx.conf
lua指令方式
在server 中添加一個(gè)localtion
location /hello { default_type 'text/plain'; content_by_lua 'ngx.say("hello, lua")'; }
然后啟動(dòng)nginx
# cd /usr/local/nginx-1.4.2/sbin # ./nginx
瀏覽器訪問:
http://127.0.0.1/hello
顯示:hello, lua
注意點(diǎn):
1.注意每個(gè)模塊的安裝目錄不能出現(xiàn)差錯(cuò)
2.如果之前通過apt-get方式安裝了nginx,需要先刪除nginx,因?yàn)榇朔绞较螺d的軟件無法編譯
3.
到此說明第三方安裝成功,
5.下面開始添加日志
http { log_format mylog 'response_body:$resp_body'; server { #記錄nginx請(qǐng)求返回值 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語言的,可以對(duì)如下代碼進(jìn)行修改,來更加符合自己的要求。
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 ';
日志輸出時(shí),會(huì)發(fā)現(xiàn)語言響應(yīng)結(jié)果涉及到字符漢字的時(shí)候轉(zhuǎn)為16進(jìn)制導(dǎo)致無法識(shí)別。
部分響應(yīng)日志如下:
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: {}}
可通過復(fù)制到python腳本進(jìn)行解決。
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'))
輸入結(jié)果為:
{"code": 404, "message": "請(qǐng)求的資源不存在", "data": {}}
總結(jié)
以上所述是小編給大家介紹的nginx日志中添加請(qǐng)求的response日志,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
標(biāo)簽:白城 岳陽 南陽 撫州 邵陽 南陽 葫蘆島 泉州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《nginx日志中添加請(qǐng)求的response日志(推薦)》,本文關(guān)鍵詞 nginx,日志,中,添加,請(qǐng)求,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。