Nginx用途 配置

2021-09-26 15:58:53 字數 3260 閱讀 2843

反向**:

反向**(reverse proxy)方式是指以**伺服器來接受internet上的連線請求,然後將請求**給內部網路上的伺服器,並將從伺服器上得到的結果返回給internet上請求連線的客戶端,此時**伺服器對外就表現為乙個反向**伺服器。簡單來說就是真實的伺服器不能直接被外部網路訪問,所以需要一台**伺服器,而**伺服器能被外部網路訪問的同時又跟真實伺服器在同乙個網路環境,當然也可能是同一臺伺服器,埠不同而已。

儲存配置檔案後啟動nginx,這樣當我們訪問localhost的時候,就相當於訪問localhost:8080了

配置檔案:

server 

# ~為正則匹配,路徑中包含***就**到對應的url

location ~ /hosp/

location ~ /cmn/

# error_page 500 502 503 504 /50x.html;

# location = /50x.html

}

負載均衡

負載均衡也是nginx常用的乙個功能,負載均衡其意思就是分攤到多個操作單元上進行執行,例如web伺服器、ftp伺服器、企業關鍵應用伺服器和其它關鍵任務伺服器等,從而共同完成工作任務。簡單而言就是當有2臺或以上伺服器時,根據規則隨機的將請求分發到指定的伺服器上處理,負載均衡配置一般都需要同時配置反向**,通過反向**跳轉到負載均衡。而nginx目前支援自帶3種負載均衡策略,還有2種常用的第三方策略。

rr(預設)

每個請求按時間順序逐一分配到不同的後端伺服器,如果後端伺服器down掉,能自動剔除。

簡單配置:

這裡我配置了2臺伺服器,當然實際上是一台,只是埠不一樣而已,而8081的伺服器是不存在的,也就是說訪問不到,但是我們訪問http://localhost 的時候,也不會有問題,會預設跳轉到http://localhost:8080 具體是因為nginx會自動判斷伺服器的狀態,如果伺服器處於不能訪問(伺服器掛了),就不會跳轉到這台伺服器,所以也避免了一台伺服器掛了影響使用的情況,由於nginx預設是rr策略,所以我們不需要其他更多的設定。

權重

指定輪詢機率,weight和訪問比率成正比,用於後端伺服器效能不均的情況。

上面的2種方式都有乙個問題,那就是下乙個請求來的時候請求可能分發到另外乙個伺服器,當我們的程式不是無狀態的時候(採用了session儲存資料),這時候就有乙個很大的很問題了,比如把登入資訊儲存到了session中,那麼跳轉到另外一台伺服器的時候就需要重新登入了,所以很多時候我們需要乙個客戶只訪問乙個伺服器,那麼就需要用iphash了,iphash的每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問乙個後端伺服器,可以解決session的問題。

fair(第三方)

按後端伺服器的響應時間來分配請求,響應時間短的優先分配。

url_hash(第三方)

按訪問url的hash結果來分配請求,使每個url定向到同乙個後端伺服器,後端伺服器為快取時比較有效。 在upstream中加入hash語句,server語句中不能寫入weight等其他的引數,hash_method是使用的hash演算法

以上5種負載均衡各自適用不同情況下使用,所以可以根據實際情況選擇使用哪種策略模式,不過fair和url_hash需要安裝第三方模組才能使用

http伺服器

nginx本身也是乙個靜態資源的伺服器,當只有靜態資源的時候,就可以使用nginx來做伺服器,同時現在也很流行動靜分離,就可以通過nginx來實現,首先看看nginx做靜態資源伺服器

這樣如果訪問http://localhost 就會預設訪問到e盤wwwroot目錄下面的index.html,如果乙個**只是靜態頁面的話,那麼就可以通過這種方式來實現部署。

動靜分離

動靜分離是讓動態**裡的動態網頁根據一定規則把不變的資源和經常變的資源區分開來,動靜資源做好了拆分以後,我們就可以根據靜態資源的特點將其做快取操作,這就是**靜態化處理的核心思路

這樣我們就可以吧html以及和css以及js放到wwwroot目錄下,而tomcat只負責處理jsp和請求,例如當我們字尾為gif的時候,nginx缺省會從wwwroot獲取到當前請求的動態**件返回,當然這裡的靜態檔案跟nginx是同一臺伺服器,我們也可以在另外一台伺服器,然後通過反向**和負載均衡配置過去就好了,只要搞清楚了最基本的流程,很多配置就很簡單了,另外localtion後面其實是乙個正規表示式,所以非常靈活

正向**

正向**,意思是乙個位於客戶端和原始伺服器(origin server)之間的伺服器,為了從原始伺服器取得內容,客戶端向**傳送乙個請求並指定目標(原始伺服器),然後**向原始伺服器轉交請求並將獲得的內容返回給客戶端。客戶端才能使用正向**。當你需要把你的伺服器作為**伺服器的時候,可以用nginx來實現正向**,但是目前nginx有乙個問題,那麼就是不支援https

resolver是配置正向**的dns伺服器,listen 是正向**的埠,配置好了就可以在ie上面或者其他**外掛程式上面使用伺服器ip+埠號進行**了。

nginx用途 負載均衡

負載均衡 個人理解即是,在集群環境下,把伺服器的壓力平均分攤到不同的伺服器,盡量不讓其中某一台伺服器的壓力特別大,其他伺服器卻比較小,這樣伺服器集群的穩定性不夠高。這裡,我們啟動兩台tomcat伺服器來進行測試。tomcat1埠為8080,tomcat埠號為8081 修改預設首頁內容 vi inde...

Nginx的用途和負載均衡演算法

nginx應該是現在最火的web和反向 伺服器,沒有之一。她是一款誕生於俄羅斯的高效能web伺服器,尤其是在高併發的情況下,相較於apache,有優異的表現。那除了負載均衡,她還有什麼其他的用途呢。nginx擅長處理靜態檔案,是非常好的 檔案伺服器。把所有的靜態資源放到nginx上,可以使應用動靜分...

centos 7安裝nginx以及用途

安裝依賴環境 引入映象源 vi etc yum.repos.d nginx.repo 建立編輯nginx.repo 新增以下內容 nginx stable name nginx stable repo baseurl gpgcheck 1 enabled 1 gpgkey module hotfix...