欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年05月04日 17:23:55   作者:RGC  
這篇文章主要介紹了nginx日志中添加請(qǐng)求的response日志,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

由于此功能在nginx內(nèi)置的功能中沒(méi)有,需要安裝第三方模塊ngx_lua,由于此模塊需要Lua語(yǔ)言,所以需要安裝相應(yīng)的Lua語(yǔ)言包

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

瀏覽器訪問(wèn):

http://127.0.0.1/hello

顯示:hello, lua

注意點(diǎn):

1.注意每個(gè)模塊的安裝目錄不能出現(xiàn)差錯(cuò)

2.如果之前通過(guò)apt-get方式安裝了nginx,需要先刪除nginx,因?yàn)榇朔绞较螺d的軟件無(wú)法編譯

3.

到此說(shuō)明第三方安裝成功,

5.下面開(kāi)始添加日志

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語(yǔ)言的,可以對(duì)如下代碼進(jìn)行修改,來(lái)更加符合自己的要求。

  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ǔ)言響應(yīng)結(jié)果涉及到字符漢字的時(shí)候轉(zhuǎn)為16進(jìn)制導(dǎo)致無(wú)法識(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: {}}

可通過(guò)復(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ì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Nginx實(shí)現(xiàn)動(dòng)靜分離的示例代碼

    Nginx實(shí)現(xiàn)動(dòng)靜分離的示例代碼

    這篇文章主要介紹了Nginx實(shí)現(xiàn)動(dòng)靜分離的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Nginx rewrite跳轉(zhuǎn)應(yīng)用場(chǎng)景詳解

    Nginx rewrite跳轉(zhuǎn)應(yīng)用場(chǎng)景詳解

    這篇文章主要介紹了Nginx rewrite跳轉(zhuǎn)應(yīng)用場(chǎng)景詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Nginx搭建流媒體FLV視頻服務(wù)器配置示例

    Nginx搭建流媒體FLV視頻服務(wù)器配置示例

    這篇文章主要介紹了Nginx搭建流媒體FLV視頻服務(wù)器配置示例,,需要的朋友可以參考下
    2014-08-08
  • Nginx日志按日期切割詳解(按天切割)

    Nginx日志按日期切割詳解(按天切割)

    由于nginx的日志本身只是支持按照server_name或者大小進(jìn)行劃分,對(duì)于習(xí)慣了apache的按照一個(gè)網(wǎng)站每天一個(gè)日志的我來(lái)說(shuō)是不可以接受的,所以就實(shí)現(xiàn)了按天切割的功能,這篇文章主要介紹了關(guān)于Nginx日志按日期切割的相關(guān)資料,需要的朋友可以參考下。
    2017-03-03
  • nginx動(dòng)態(tài)添加訪問(wèn)白名單的方法

    nginx動(dòng)態(tài)添加訪問(wèn)白名單的方法

    本篇文章主要介紹了nginx動(dòng)態(tài)添加訪問(wèn)白名單的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • 記錄Nginx服務(wù)器的Split Clients模塊配置過(guò)程

    記錄Nginx服務(wù)器的Split Clients模塊配置過(guò)程

    這篇文章主要介紹了Nginx服務(wù)器的Split Clients模塊的配置過(guò)程記錄,ngx-http-split-clients模塊用于切分客戶端連接,需要的朋友可以參考下
    2016-01-01
  • 詳解nginx進(jìn)程鎖的實(shí)現(xiàn)

    詳解nginx進(jìn)程鎖的實(shí)現(xiàn)

    nginx是多進(jìn)程并發(fā)模型的應(yīng)用,但為了網(wǎng)絡(luò)請(qǐng)求的安全性,必須要使用到鎖,那么這個(gè)進(jìn)程鎖如何實(shí)現(xiàn)呢
    2021-06-06
  • 詳解 Nginx代理功能與負(fù)載均衡

    詳解 Nginx代理功能與負(fù)載均衡

    本篇文章主要介紹了詳解 Nginx代理功能與負(fù)載均衡,先描述一些關(guān)于代理功能的配置,再說(shuō)明負(fù)載均衡詳細(xì),有興趣的可以了解一下。
    2017-02-02
  • nginx 配置代理服務(wù)地址最后多加反斜杠和不加反斜杠的區(qū)別小結(jié)

    nginx 配置代理服務(wù)地址最后多加反斜杠和不加反斜杠的區(qū)別小結(jié)

    在使用Nginx配置代理服務(wù)時(shí),地址最后是否添加反斜杠(/)會(huì)對(duì)代理的URL處理產(chǎn)生影響,下面就來(lái)具體介紹一下,感興趣的可以了解一下
    2024-08-08
  • nginx中使用lua腳本的方法

    nginx中使用lua腳本的方法

    這篇文章主要介紹了nginx中使用lua腳本的方法,本文介紹通過(guò)第三方模塊lua-nginx-module實(shí)現(xiàn)lua腳本在nginx的調(diào)用,并附一個(gè)配置例子,需要的朋友可以參考下
    2014-07-07

最新評(píng)論