Nginx 的一些常見功能(windows,AspNet ,IIS)
下載
官方網站:https://nginx.org/en/download.html
下載,解壓縮是這個樣子
啟動:
啟動方式有兩種
方式一:雙擊nginx.exe
方式二:進入cmd 到該目錄下,運行 start nginx
啟動閃退,查看錯誤日志,原因是80端口已經被占用了,所以我們找到nginx.conf文件,換了一個監聽的端口8085
錯誤日志文件
,再次啟動,啟動成功,啟動成功。發現多了一個nginx.pid文件,在瀏覽器里面訪問localhost:8035
這個樣子就是成功了
這里是日志文件
記錄了每次請求
接下來,我們做第一個nginx常用的功能:
使用ngxix負載均衡
把請求分散到多個主機
這里我們新建了一個aspnetmvc項目,功能很簡單,
發布之后,復制兩個一樣的文件夾,只改動web。Config里面的serverid。分別部署到8001端口,8002端口
8001的配置文件
8002的配置文件
Serverid 1
Serverid 2
我們的目標是:訪問8035端口時,將請求通過nginx轉到8001和8002
配置前:
8085
8001
8002
開始配置
1,在server節點上面加入 upstream節點,起個名字 my_web_server,
在大括號里面加入要映射的地址,格式是 server + 地址 +權重,權重越高,訪問越多
2,修改server節點,里面的server_name 和上面保持一致
3,修改 location 節點 名字也要和上面保持一致
齊活。
保存配置文件,在cmd中重啟nginx配置文件
重啟命令 nginx –s reload
然后我們再去訪問8085 ,配置成功
,
可以看到一次1,一次二,目前是兩個不加任何策略配置
接下來我們加上ip_hash 的策略
接着訪問多次8085
,發現他只會映射到8001上面去,這個就是ip_hash策略的作用:根據不通ip的哈希值,指定到固定端口上面去,ip_hash是很常用的一種策略,可以解決一點點的session不共享問題
其他的幾種策略這里不再贅述,
可以去看看這里 https://blog.csdn.net/balalamm/article/details/79916483
使用nginx代理二級目錄
我們經常會遇到這樣的 結構
比如說這是某個應用的接口地址http://api.example.com/,他有v1和v2兩個版本
放在不同的服務器或者端口上,我們想使用下面的url來請求
http://api.example.com/v1/ 和 http://api.example.com/v2/
這時候我們就可以是用nginx來處理
我們的目標是
請求 http://localhost:8085/v1/ 轉到8001端口
請求 http://localhost:8085/v2/ 轉到8002端口
修改配置文件,這里暫時用不到upstream 節點了
修改成這個樣子
加一個location 就行,是不是很簡單,注意8001/后面的斜杠 /一定不能少
效果圖 v1/
V2/
Nginx的功能是十分強大,以上只是基礎,其他的功能比如:使用nginx防盜鏈,請求日志記錄,攔截請求等等,使用nginx實現要比在應用程序中實現簡單快捷很多,總而言之就是nginx很有學習的必要。
附錄:nginx常量對照表(原文 https://blog.csdn.net/echizao1839/article/details/80872378)
$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”。