>  기사  >  백엔드 개발  >  nginx 로그에 요청된 응답 로그를 추가합니다.

nginx 로그에 요청된 응답 로그를 추가합니다.

不言
不言원래의
2018-05-05 09:49:542627검색

이 글에서는 nginx 로그에 요청을 추가하는 응답 로그를 주로 소개합니다. 매우 훌륭하고 참고할만한 가치가 있으니 필요하신 분들은 참고하시면 됩니다.

이 기능은 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

다음 내용은 설치를 나타내는 것으로 보입니다. /usr/local ====

2에 LuaJIT 2.0.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 명령 방법

서버에 로컬 추가

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-nginx가 get 메서드로 설치된 경우 먼저 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;
   }
 }
}

이제 응답 로그가 성공적으로 추가되었습니다.

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: {x22codex22: 404, x22messagex22: x22xE8xAFxB7xE6xB1x82xE7x9Ax84xE8xB5x84xE6xBAx90xE4xB8x8DxE5xADx9 8 xE5x9CxA8x22, x22datax22: {}}


은 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 로그에 요청된 응답 로그를 추가합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.