解鎖nginx負載均衡配置及其策略「nginx負載均衡策略有哪些」

多用戶訪問出現問題

開發時,一個項目只有少數幾個人進行訪問,此時使用tomcat能夠很好地進行訪問,但訪問量大的時候服務器便不能很好的處理,有的小夥伴可能不知道什麼是tomcat

tomcat是什麼

Tomcat 是由 Apache 開發的一個 Servlet 容器,實現了對Servlet 和 JSP 的支持,並提供了作為Web服務器的一
些特有功能,如Tomcat管理和控制平台、安全域管理和Tomcat閥等。
由於 Tomcat 本身也內含了一個 HTTP 服務器,它也可以被視作一個單獨的 Web 服務器。但是,不能將
 Tomcat 和 Apache HTTP 服務器混淆,ApacheHTTP 服務器是一個用 C 語言實現的 HTTP Web 服務器;這兩
 個 HTTPweb server 不是捆綁在一起的。Tomcat 包含了一個配置管理工具,也可以通過編輯XML格式的配置文
 件來進行配置。

具體請參考官方文檔,這裡由於要介紹nginx便不再贅述

tomcat官方文檔「鏈接」

tomcat的缺點

首先不得不說,tomcat確實是一個非常好用的JavaWeb容器
但他的缺點也是顯而易見的,如下:

  • 眾所周知tomcat是一個輕量級的Web容器,並不能很好地處理一些比較複雜場景時出現的問題
  • 圖形化做的不夠直觀,給非技術用戶感覺比較不好
  • 缺少多個實例協同工作的設置,集群,多服務器
  • 缺少更多的監控功能和接口

舉個例子
最開始只有少數用戶訪問服務器

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

此時tomcat能很好的完成任務

但是當訪問量增加的時候

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

一台服務器顯然無法滿足需求
我們不得不增加多台服務器以進行處理操作
那麼問題就在於此,如果增加了多台服務器,那麼用戶又該訪問什麼呢

所以我們需要增加一個代理,用來接收用戶的所有請求並將這些請求合理分配到每台服務器上,且用戶無感知
此時nginx就是我們最好的選擇

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

Nginx是什麼

  • Nginx
    (engine x)
    是一個高性能的HTTP和反向代理web服務器,同時也提供了IMAP/POP3/SMTP服務。Nginx是由伊戈爾·賽索耶夫為俄羅斯訪問量第二的Rambler.ru站點(俄文:Рамблер)開發的,第一個公開版本0.1.0發佈於2004年10月4日。
  • 其將源代碼以類BSD許可證的形式發布,因它的穩定性、豐富的功能集、簡單的配置文件和低系統資源的消耗而聞名。2011年6月1日,nginx 1.0.4發布。
  • Nginx是一款輕量級的Web
    服務器/反向代理服務器及電子郵件(IMAP/POP3)代理服務器,在BSD-like
    協議下發行。其特點是佔有內存少,並發能力強,事實上nginx的並發能力在同類型的網頁服務器中表現較好,中國大陸使用nginx網站用戶有:百度、京東、新浪、網易、騰訊、淘寶等。

Nginx文檔

Nginx作用

正向代理

正向代理其實相當於請求的中繼,比如說,如果某個網站國內無法訪問,也就是被牆了,我可以選擇兩種方式:

  1. 配置代理服務器
  2. VPN
面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

客戶端 <一> 代理 一>服務端
舉個例子
A(客戶端)想租C(服務端)的房子,但是A(客戶端)並不認識C(服務端)租不到。
B(代理)認識C(服務端)能租這個房子所以你找了B(代理)幫忙租到了這個房子。

這個過程中C(服務端)不認識A(客戶端)只認識B(代理)
C(服務端)並不知道A(客戶端)租了房子,只知道房子租給了B(代理)。

反向代理

反向代理比正向代理更加透明,客戶端並不知道訪問的是代理服務器,當客戶端請求一個網址的時候,會經過反向代理服務器,而這台反向代理服務器,會根據客戶端的請求,將請求轉發到內網服務器中,內網服務器處理請求並返回結果到反向代理服務器上,通過反向代理服務器,將結果最終返回到客戶端,詳情如圖:

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

客戶端 一>代理 <一> 服務端
舉個例子:
A(客戶端)想租一個房子,B(代理)就把這個房子租給了他。
這時候實際上C(服務端)才是房東。
B(代理)是中介把這個房子租給了A(客戶端)。

這個過程中A(客戶端)並不知道這個房子到底誰才是房東
他都有可能認為這個房子就是B(代理)的

負載均衡

Nginx提供的負載均衡策略有2種:內置策略和擴展策略。內置策略為輪詢,加權輪詢,Ip hash。擴展策略

輪詢

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

加權輪詢

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

iphash對客戶端請求的ip進行hash操作,然後根據hash結果將同一個客戶端ip的請求分發給同一台服務器進行處理,可以解決session不共享的問題。

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

動靜分離

動靜分離,在我們的軟件開發中,有些請求是需要後台處理的,有些請求是不需要經過後台處理的(如:css、html、jpg、js等等文件),這些不需要經過後台處理的文件稱為靜態文件。讓動態網站里的動態網頁根據一定規則把不變的資源和經常變的資源區分開來,動靜資源做好了拆分以後,我們就可以根據靜態資源的特點將其做緩存操作。提高資源響應的速度。

面試被問到倒了!為什麼要使用Nginx?什麼時候需要使用Nginx?

配置(本系列會有我對相關配置的理解及應用)

###靜態資源訪問
server {
  listen       80;
  server_name  hello.cq.com;
  location /static {
       root 	/Users/cq/study;
       index  index.html index.htm;
   }
}
###動態資源訪問
 server {
  listen       80;
  server_name  www.cq.com;
    
  location / {
    proxy_pass http://127.0.0.1:8080;
     index  index.html index.htm;
   }
}

Nginx優點

1.Nginx 可以在大多數 Unix Linux OS 上編譯運行,並有 Windows 移植版。 Nginx 的1.20.0穩定版已經於2021年4月20日發布,一般情況下,對於新建站點,建議使用最新穩定版作為生產版本,已有站點的升級急迫性不高。Nginx 的源代碼使用 2-clause BSD-like license。

2.Nginx 是一個很強大的高性能Web和反向代理服務

3.在連接高並發的情況下,Nginx是Apache服務不錯的替代品:Nginx在美國是做虛擬主機生意的老闆們經常選擇的軟件平台之一。能夠支持高達 50,000 個並發連接數的響應,感謝Nginx為我們選擇了 epoll and kqueue作為開發模型。

服務器方面

  1. Nginx作為負載均衡服務:Nginx 既可以在內部直接支持 Rails 和 PHP 程序對外進行服務,也可以支持作為 HTTP代理服務對外進行服務。Nginx採用C進行編寫,不論是系統資源開銷還是CPU使用效率都比 Perlbal 要好很多。
  2. 處理靜態文件,索引文件以及自動索引;打開文件描述符緩衝。
  3. 無緩存的反向代理加速,簡單的負載均衡和容錯。
  4. FastCGI,簡單的負載均衡和容錯。
  5. 模塊化的結構。包括 gzipping, byte ranges, chunked responses,以及 SSI-filter 等 filter。如果由 FastCG或其它代理服務器處理單頁中存在的多個 SSI,則這項處理可以並行運行,而不需要相互等待。
  6. 支持 SSL 和 TLSSNI。

代碼方面

Nginx代碼完全用C語言從頭寫成,已經移植到許多體系結構和操作系統,包括:Linux、FreeBSD、Solaris、Mac OS X、AIX以及Microsoft Windows。Nginx有自己的函數庫,並且除了zlib、PCRE和OpenSSL之外,標準模塊只使用系統C庫函數。而且,如果不需要或者考慮到潛在的授權衝突,可以不使用這些第三方庫。

代理服務器

  • 作為郵件代理服務:Nginx 同時也是一個非常優秀的郵件代理服務(最早開發這個產品的目的之一也是作為郵件代理服務器),Last.fm 描述了成功並且美妙的使用經驗。
  • Nginx 是一個安裝非常的簡單、配置文件非常簡潔(還能夠支持perl語法)、Bug非常少的服務。Nginx 啟動特別容易,並且幾乎可以做到7*24不間斷運行,即使運行數個月也不需要重新啟動。你還能夠不間斷服務的情況下進行軟件版本的升級。

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/281189.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-21 13:16
下一篇 2024-12-21 13:16

相關推薦

發表回復

登錄後才能評論