Nginx 的簡單使用 (IIS,Asp.Net)


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”。

 


免責聲明!

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



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