7-nginx 配置記錄 http 請求參數(如記錄URL參數)的 log 和 nginx 常見的一些內置變量


在前后端分離的開發過程中,我們經常會遇到一些莫名其妙的問題。比如:后端開發在 Swagger 上對接口進行測試沒有問題,而前端或者 APP 端一調用就出問題。A 說 A 沒錯,B 說 B 沒錯。請求參數都是按照要求進行傳遞的,那到底是誰的錯呢?

為了解決這個問題,我們一般會進行抓包,但是抓包呢有時候不太好使用,比如針對 NAT 的情況,以及 MAC 等環境下,不太好抓。也有人說,在后端將具體的請求參數打印 log,看看 log 就可以了。但是這樣做太麻煩了,我將每個接口都打印一下 log,或者說為了 log,我需要重新發一個版本,雖然是在測試環境。頻繁的發版並不好,且不說一些應用,編譯一下,部署一下,啟動一下半天就過去了。那說了這么多該到底怎么解決呢?

答案就是本文的主題,使用 nginx 或者 tomcat 記錄每個請求的請求頭加參數信息。這樣在測試環境中所有的接口,所有的請求都可以獲取到。

在 nginx 中配置下面的信息即可實現請求參數的日志打印。

log_format access '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" $http_x_forwarded_for';
access_log /var/log/51yip.log access;

這段配置,可以記錄用戶 ip,用戶真實 ip,用戶訪問時間,用戶訪問的游覽器信息等。以 $ 開頭的變量都是 nginx 自帶的一些變量。這些變量還有很多,通稱為內置變量。下面是羅列的一些常見的內置變量:

  • $arg_PARAMETER 這個變量包含在查詢字符串時GET請求PARAMETER的值。
  • $args 這個變量等於請求行中的參數。
  • $binary_remote_addr 二進制碼形式的客戶端地址。
  • $body_bytes_sent
  • $content_length 請求頭中的Content-length字段。
  • $content_type 請求頭中的Content-Type字段。
  • $cookie_COOKIE cookie COOKIE的值。
  • $document_root 當前請求在root指令中指定的值。
  • $document_uri 與$uri相同。
  • $host 請求中的主機頭字段,如果請求中的主機頭不可用,則為服務器處理請求的服務器名稱。
  • $is_args 如果$args設置,值為"?",否則為""。
  • $limit_rate 這個變量可以限制連接速率。
  • $nginx_version 當前運行的nginx版本號。
  • $query_string 與$args相同。
  • $remote_addr 客戶端的IP地址。
  • $remote_port 客戶端的端口。
  • $remote_user 已經經過Auth Basic Module驗證的用戶名。
  • $request_filename 當前連接請求的文件路徑,由root或alias指令與URI請求生成。
  • $request_body 這個變量(0.7.58+)包含請求的主要信息。在使用proxy_pass或fastcgi_pass指令的location中比較有意義。
  • $request_body_file 客戶端請求主體信息的臨時文件名。
  • $request_completion 請求完成
  • $request_method 這個變量是客戶端請求的動作,通常為GET或POST。包括0.8.20及之前的版本中,這個變量總為main request中的動作,如果當前請求是一個子請求,並不使用這個當前請求的動作。
  • $request_uri 這個變量等於包含一些客戶端請求參數的原始URI,它無法修改,請查看$uri更改或重寫URI。
  • $schemeHTTP 方法(如http,https)。按需使用,例:rewrite ^(.+)$ $scheme://example.com$1 redirect;
  • $server_addr 服務器地址,在完成一次系統調用后可以確定這個值,如果要繞開系統調用,則必須在listen中指定地址並且使用bind參數。
  • $server_name 服務器名稱。
  • $server_port 請求到達服務器的端口號。
  • $server_protocol 請求使用的協議,通常是HTTP/1.0或HTTP/1.1。
  • $uri 請求中的當前URI(不帶請求參數,參數位於$args),可以不同於瀏覽器傳遞的$request_uri的值,它可以通過內部重定向,或者使用index指令進行修改。

這只是一些常用的內置變量,還有很多不常用的,建議大家查看官方文檔。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM