在配置基於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 |
|