多用戶訪問出現問題
開發時,一個專案只有少數幾個人進行訪問,此時使用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容器,并不能很好地處理一些比較復雜場景時出現的問題
- 圖形化做的不夠直觀,給非技術用戶感覺比較不好
- 缺少多個實體協同作業的設定,集群,多服務器
- 缺少更多的監控功能和介面
舉個例子
最開始只有少數用戶訪問服務器

此時tomcat能很好的完成任務
但是當訪問量增加的時候

一臺服務器顯然無法滿足需求
我們不得不增加多臺服務器以進行處理操作
那么問題就在于此,如果增加了多臺服務器,那么用戶又該訪問什么呢
所以我們需要增加一個代理,用來接收用戶的所有請求并將這些請求合理分配到每臺服務器上,且用戶無感知
此時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作用
正向代理
正向代理其實相當于請求的中繼,比如說,如果某個網站國內無法訪問,也就是被墻了,我可以選擇兩種方式:
- 配置代理服務器
- VPN

客戶端 <一> 代理 一>服務端
舉個例子
A(客戶端)想租C(服務端)的房子,但是A(客戶端)并不認識C(服務端)租不到,
B(代理)認識C(服務端)能租這個房子所以你找了B(代理)幫忙租到了這個房子,
這個程序中C(服務端)不認識A(客戶端)只認識B(代理)
C(服務端)并不知道A(客戶端)租了房子,只知道房子租給了B(代理),
反向代理
反向代理比正向代理更加透明,客戶端并不知道訪問的是代理服務器,當客戶端請求一個網址的時候,會經過反向代理服務器,而這臺反向代理服務器,會根據客戶端的請求,將請求轉發到內網服務器中,內網服務器處理請求并回傳結果到反向代理服務器上,通過反向代理服務器,將結果最侄訓傳到客戶端,詳情如圖:

客戶端 一>代理 <一> 服務端
舉個例子:
A(客戶端)想租一個房子,B(代理)就把這個房子租給了他,
這時候實際上C(服務端)才是房東,
B(代理)是中介把這個房子租給了A(客戶端),
這個程序中A(客戶端)并不知道這個房子到底誰才是房東
他都有可能認為這個房子就是B(代理)的
負載均衡
Nginx提供的負載均衡策略有2種:內置策略和擴展策略,內置策略為輪詢,加權輪詢,Ip hash,擴展策略
輪詢

加權輪詢

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

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

配置(本系列會有我對相關配置的理解及應用)
###靜態資源訪問
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優點
- Nginx 可以在大多數 Unix Linux OS 上編譯運行,并有 Windows 移植版, Nginx 的1.20.0穩定版已經于2021年4月20日發布,一般情況下,對于新建站點,建議使用最新穩定版作為生產版本,已有站點的升級急迫性不高,Nginx 的源代碼使用 2-clause BSD-like license,
- Nginx 是一個很強大的高性能Web和反向代理服務
- 在連接高并發的情況下,Nginx是Apache服務不錯的替代品:Nginx在美國是做虛擬主機生意的老板們經常選擇的軟體平臺之一,能夠支持高達 50,000 個并發連接數的回應,感謝Nginx為我們選擇了 epoll and kqueue作為開發模型,
服務器方面
- Nginx作為負載均衡服務:Nginx 既可以在內部直接支持 Rails 和 PHP 程式對外進行服務,也可以支持作為 HTTP代理服務對外進行服務,Nginx采用C進行撰寫,不論是系統資源開銷還是CPU使用效率都比 Perlbal 要好很多,
- 處理靜態檔案,索引檔案以及自動索引;打開檔案描述符緩沖,
- 無快取的反向代理加速,簡單的負載均衡和容錯,
- FastCGI,簡單的負載均衡和容錯,
- 模塊化的結構,包括 gzipping, byte ranges, chunked responses,以及 SSI-filter 等 filter,如果由 FastCG或其它代理服務器處理單頁中存在的多個 SSI,則這項處理可以并行運行,而不需要相互等待,
- 支持 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不間斷運行,即使運行數個月也不需要重新啟動,你還能夠不間斷服務的情況下進行軟體版本的升級,
下期:Linux下安裝Nginx,敬請期待…
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/289239.html
標籤:其他
上一篇:簡單聊聊負載均衡的那些事
下一篇:深入決議JS的宏任務和微任務
