Nginx 的內置變量

在配置基於Nginx服務器的網站時,必然會使用到Nginx內置變量配置相關信息,下面將根據網上的相關資料進行整理,以方便在配置Nginx時查詢。php

內置變量存放在 ngx_http_core_module 模塊中,變量的命名方式和 apache 服務器變量是一致的。總而言之,這些變量表明着客戶端請求頭的內容,例如 $http_user_agent , $http_cookie , 等等。下面是Nginx支持的全部內置變量html

變量名 註釋
$arg_name 請求中的的參數名,即「?」後面的arg_name=arg_value形式的arg_name
$args 請求中的參數值
$binary_remote_addr 客戶端地址的二進制形式, 固定長度爲4個字節
$body_bytes_sent 傳輸給客戶端的字節數,響應頭不計算在內;這個變量和Apache的mod_log_config模塊中的「%B」參數保持兼容
$bytes_sent 傳輸給客戶端的字節數 (1.3.8, 1.2.5)
$connection TCP鏈接的序列號 (1.3.8, 1.2.5)
$connection_requests TCP鏈接當前的請求數量 (1.3.8, 1.2.5)
$content_length 「Content-Length」 請求頭字段
$content_type 「Content-Type」 請求頭字段
$cookie_name cookie名稱
$document_root 當前請求的文檔根目錄或別名
$document_uri 同 $uri
$host 優先級以下:HTTP請求行的主機名>」HOST」請求頭字段>符合請求的服務器名
$hostname 主機名
$http_name 匹配任意請求頭字段; 變量名中的後半部分「name」能夠替換成任意請求頭字段,如在配置文件中須要獲取http請求頭:「Accept-Language」,那麼將「-」替換爲下劃線,大寫字母替換爲小寫,形如:$http_accept_language便可。
$https 若是開啓了SSL安全模式,值爲「on」,不然爲空字符串。
$is_args 若是請求中有參數,值爲「?」,不然爲空字符串。
$limit_rate 用於設置響應的速度限制,詳見 limit_rate。
$msec 當前的Unix時間戳 (1.3.9, 1.2.6)
$nginx_version nginx版本
$pid 工做進程的PID
$pipe 若是請求來自管道通訊,值爲「p」,不然爲「.」 (1.3.12, 1.2.7)
$proxy_protocol_addr 獲取代理訪問服務器的客戶端地址,若是是直接訪問,該值爲空字符串。(1.5.12)
$proxy_protocol_port 獲取代理訪問服務器的客戶端的端口,若是是直接訪問,該值爲空字符串(1.11.0)。
$query_string 同 $args
$realpath_root 當前請求的文檔根目錄或別名的真實路徑,會將全部符號鏈接轉換爲真實路徑。
$remote_addr 客戶端地址
$remote_port 客戶端端口
$remote_user 用於HTTP基礎認證服務的用戶名
$request 表明客戶端的請求地址
$request_body 客戶端的請求主體,此變量可在location中使用,將請求主體經過proxy_pass, fastcgi_pass, uwsgi_pass, 和 scgi_pass傳遞給下一級的代理服務器。
$request_body_file 將客戶端請求主體保存在臨時文件中。文件處理結束後,此文件需刪除。若是須要之一開啓此功能,須要設置client_body_in_file_only。若是將次文件傳遞給後端的代理服務器,須要禁用request body,即設置proxy_pass_request_body off,fastcgi_pass_request_body off, uwsgi_pass_request_body off, or scgi_pass_request_body off 。
$request_completion 若是請求成功,值爲」OK」,若是請求未完成或者請求不是一個範圍請求的最後一部分,則爲空。
$request_filename 當前鏈接請求的文件路徑,由root或alias指令與URI請求生成。
$request_id 16隨機字節(十六進制)生成的惟一請求標識符(1.11.0)
$request_length 請求的長度 (包括請求的地址, http請求頭和請求主體) (1.3.12, 1.2.7)
$request_method HTTP請求方法,一般爲「GET」或「POST」
$request_time 處理客戶端請求使用的時間 (1.3.9, 1.2.6); 從讀取客戶端的第一個字節開始計時。
$request_uri 這個變量等於包含一些客戶端請求參數的原始URI,它沒法修改,請查看$uri更改或重寫URI,不包含主機名,例如:」/cnphp/test.php?arg=freemouse」。
$scheme 請求使用的Web協議, 「http」 或 「https」
$sent_http_name 能夠設置任意http響應頭字段; 變量名中的後半部分「name」能夠替換成任意響應頭字段,如須要設置響應頭Content-length,那麼將「-」替換爲下劃線,大寫字母替換爲小寫,形如:$sent_http_content_length 4096便可。
$server_addr 服務器端地址,須要注意的是:爲了不訪問linux系統內核,應將ip地址提早設置在配置文件中。
$server_name 服務器名,www.nginx.org
$server_port port of the server which accepted a request
$server_protocol 服務器的HTTP版本, 一般爲 「HTTP/1.0」 或 「HTTP/1.1」 , 「HTTP/2.0」
$status HTTP響應代碼 (1.3.2, 1.2.2)
$tcpinfo_rtt、$tcpinfo_rttvar、$tcpinfo_snd_cwnd、$tcpinfo_rcv_space 客戶端TCP鏈接的具體信息
$time_iso8601 服務器時間的ISO 8610格式 (1.3.12, 1.2.7)
$time_local 服務器時間(LOG Format 格式) (1.3.12, 1.2.7)
$uri
請求中的當前URI(不帶請求參數,參數位於$args),能夠不一樣於瀏覽器傳遞的$request_uri的值,它能夠經過內部重定向,或者使用index指令進行修改,$uri不包含主機名,如」/foo/bar.html」。


相關文章
相關標籤/搜索