最新版nginx內建變數
在配置基於nginx伺服器的網站時,必然會用到 nginx內建變數 ,下面筆者將它整理成列表,把最新版本的變數列出來,以方便做配置時查詢
nginx內建變數
內建變數存放在 ngx_http_core_module 模組中,變數的命名方式和apache 伺服器變數是一致的。總而言之,這些變數代表著客戶端請求頭的內容,例如$http_user_agent, $http_cookie, 等等。下面是nginx支援的所有內建變數:
$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)
$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_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.cnphp.info
$server_port
伺服器埠
$server_protocol
伺服器的HTTP版本, 通常為 “HTTP/1.0” 或 “HTTP/1.1”
$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”。