国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

web 容器的設計如何實現

2019-11-26 13:29:57
字體:
來源:轉載
供稿:網友

web 容器的設計

開發一個web容器涉及很多不同方面不同層面的技術,例如通信層的知識,程序語言層面的知識等等,且一個可用的web容器是一個比較龐大的系統,要說清楚需要很長的篇幅,本文旨在介紹如何設計一個web容器,只探討實現的思路,并不涉及過多的具體實現。把它分解劃分成若干模塊和組件,每個組件模塊負責不同的功能,下圖列出一些基本的組件,并將對每個組件進行介紹。

 web容器,設計,JSP

連接接收器

主要的職責就是監聽是否有客戶端套接字連接并接收socket,再將socket交由任務執行器(線程池)執行。不斷從系統底層讀取socket,做盡可能少的處理,再扔進線程池。為什么強調要做盡可能少的處理?這里關系到系統性能問題,過多的處理會嚴重影響吞吐量。因為一般只有一個接收器(一條線程負責套接字接收工作),所以它對每次接收處理的時間長短將很可能對整體性能產生影響。于是接收器所干的活都是非常少且簡單的,僅僅維護了幾個狀態變量、流量控制閘門的累加操作、serverSocket的接收操作、設置接收到的socket的一些屬性、將接收到的socket放入線程池以及一些異常處理。其他需要較長時間處理的邏輯就交給了線程池,例如對socket底層數據的讀取,對http協議報文的解析及響應客戶端的一些操作等等。

web容器,設計,JSP

連接數控制器

對于一臺機器而言,訪問請求的總流量有高峰期且服務器有物理極限,為了保證web服務器不被沖垮我們需要采取一些措施進行保護預防,需要稍微說明的此處的流量更多的是指套接字的連接數,通過控制套接字連接個數來控制流量。其中一種有效的方法就是采取流量控制,它就像在流量的入口增加了一道閘門,閘門的大小決定了流量的大小,一旦達到最大流量將關閉閘門停止接收直到有空閑通道。計數器可用JDK的AQS框架實現。

web容器,設計,JSP

套接字工廠

不同的使用場合可能需要不同的安全級別,例如在支付相關的交易就必須對信息加密后再發送,這其中還涉及到密鑰協商的過程,而在另外一些普通場合則無需對報文加密。反應到應用層則是使用http與https的問題。
簡單講TLS/SSL協議給每次通信①提供認證服務,認證本次會話實體身份的合法性。②提供加密服務,強加密機制能保證通信過程中的消息不會被破譯。③提供防篡改服務,利用Hash算法對消息進行簽名,通過驗證簽名保證通信內容不被篡改。
http協議對應Socket,而https則對應SSLSocket。如何生成Socket及SSLSocket則交由套接字工廠。

web容器,設計,JSP

任務定義器――Task

定義需要執行的任務,告訴線程池要執行什么樣的任務。任務主要分為三點:處理socket并響應客戶端、連接數計數器減一、關閉socket。其中對socket的處理是最重要也是最復雜的,它包括對底層socket字節流的讀取、http協議請求報文的解析(請求行、請求頭、請求體等信息的解析)、根據請求行解析得到路徑去尋找相應主機上web項目的資源、根據處理的結果組裝好http協議響應報文輸出到客戶端。

web容器,設計,JSP

任務執行器

一個擁有最大最小線程數限制的線程池,之所以稱之為“任務執行器”是因為線程池可以看做是啟動了若干線程不斷檢測某個任務隊列,一旦發現有需要執行的任務則執行。最大最小線程數限制、多余線程回收時間限制、超出最大線程數時線程池做出的拒絕動作等等。

web容器,設計,JSP

報文讀取

用于向操作系統底層讀取來自客戶端的報文并提供緩沖機制。報文復制到desBuf。

web容器,設計,JSP

報文輸出

用于向操作系統底層寫入由web容器處理后的報文并提供緩沖機制。將報文outputBuf通過緩沖區寫入到操作系統。

web容器,設計,JSP

輸入過濾器

在這個讀取的過程中希望做一些額外的處理,并且這些額外處理可能是根據不同條件做不同的處理,考慮到程序解耦與擴展,于是引入過濾器。通過一層層的過濾器完成過濾操作后才能到desBuf,這個過程就像被加入了一道道處理關卡,經過關卡都會被執行相應操作,最終完成源數據到目的數據的操作。

web容器,設計,JSP

輸出過濾器

與輸入過濾器功能類似,用于在報文輸出的時候。

web容器,設計,JSP

報文解析器

提供解析http協議各個部分的能力。

web容器,設計,JSP

請求生成器

按照面向對象的思想,把每個請求過程中與請求相關的屬性及協議字段等抽象成一個Request對象。包括請求行、請求頭、請求體三部分信息,在處理過程中需要什么值可直接從request對象中獲取。為實現servlet標準提供方便。


web容器,設計,JSP

響應生成器

與請求相對應,需要一個響應對象生成器。包括響應行、響應頭、響應體三部分信息,在處理結果相關值可直接設置到response對象中。為實現servlet標準提供方便。

web容器,設計,JSP

地址映射器

地址映射器是請求與各個web項目、各個資源的路由器。一個請求的訪問根據路徑被映射找到響應的資源輸出給請求客戶端。

web容器,設計,JSP

生命周期

為了進一步模塊化,整個容器擁有很多組件,這些組件可能在不同的時刻需要做不同的事件,需要一個生命周期統一把所有組件管理起來。例如所有組件的啟動、停止、關閉等操作都抽離由生命周期統一管理,就可以方便管理這些組件的生命周期。希望在某某狀態事情發生之前之后做點什么?添加一個生命周期監聽器即可優雅實現。

web容器,設計,JSP

JMX管理器

系統運行狀態的監控及管理,服務器性能、服務器相關參數的收集、JVM負載、web連接數、線程池、數據庫連接池、緩存管理、配置文件重新加載等方面。可提供一些遠程可視化管理,實時性高。同時也為分布式系統的管理提供了一個解決方案。

web容器,設計,JSP

Web載入器

WebLoader用于加載web應用項目,一個web容器可能包含了若干個web應用。為了達到lib及servlet的隔離,對于每個web應用要使用不同的類加載器ClassLoader,且這些類加載器不是父子關系,以此達到class隔離效果,即一個web應用的lib不會被其他web應用使用。

web容器,設計,JSP

會話管理器

會話管理器主要對session進行管理,包括:①生成sessionid,一般cookies或url未帶jsessionid值則認為不存在會話,需要重新生成sessionid用作會話id。②很多客戶端的會話都保存在服務器中,對于超時的會話要定期清理以確保服務器內存不會浪費。③對于一些重要的會話可以持久化到磁盤,需要時可重新加載到內存中使用。

web容器,設計,JSP

運行日志

對運行時一些警告、異常、錯誤進行記錄。

web容器,設計,JSP

訪問日志

訪問日志一般會記錄客戶端的訪問相關信息,包括客戶端ip、請求時間、請求協議、請求方法、請求字節數、響應碼、會話id、處理時間等等。訪問日志可以統計訪問用戶的數量、訪問時間分布等規律及個人愛好等等,這些數據可以幫助公司在運營策略上做出抉擇。

web容器,設計,JSP

安全管理器

Web項目運行在web容器平臺上,這就好比將一個應用嵌入到一個平臺上面運行,要使嵌入的程序能正常運行,首先平臺要能安全正常運行。并且要最大程度做到平臺不受嵌入的應用程序影響,兩者在一定程度上達到隔離的效果。啟動時通過-Djava.security.manager -Djava.security.policy==web.policy指定policy文件,此文件定義了各種權限。

web容器,設計,JSP

運行監控&遠程管理

提供一個可以實時監控web容器運行狀態的平臺,并且能進行遠程管理。

web容器,設計,JSP

集群

集群一般有兩種:①負載均衡集群,一般是通過一定的分發算法把訪問流量均勻分布到集群里面的各個機器上進行處理。②高可用集群,集群通信把若干機器連接起來,這種集群更偏重的是當集群中某個機器發生故障后能通過自動切換或流量轉移等措施來保證整個集群對外的可用性。
web一般請求都是無狀態,可以直接做集群,但涉及session則屬于有狀態,需要使用集群通信技術進行session拷貝。相關技術包括組播、單播。

web容器,設計,JSP

Servlet引擎

servlet引擎利用反射把web應用中的servlet及jsp生成對象并放入servlet對象池中,并根據實際調用相應的方法。web應用將業務邏輯處理都放在dopost或doget方法中,web容器處理請求時就會按照這里定義好的處理邏輯進行處理,處理完響應客戶端。

web容器,設計,JSP

JSP編譯器

按照規范JSP最終都是被編譯成servlet執行,所以要按照規范對jsp文件進行編譯。JSP編譯器其實就是對jsp語法進行翻譯,根據jsp語法處理。

web容器,設計,JSP

一個web容器基本包含以上介紹的組件的功能,根據各個組件模塊進行實現即可搭建起一個可以讓你的web運行起來的web容器。

 感謝閱讀,希望能幫助到大家,謝謝大家對本站 的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 绵阳市| 义乌市| 辰溪县| 婺源县| 山东省| 土默特右旗| 班戈县| 筠连县| 肃北| 类乌齐县| 彭山县| 东明县| 若羌县| 汽车| 三河市| 陇川县| 兰考县| 新巴尔虎右旗| 济源市| 泉州市| 抚远县| 吉木萨尔县| 隆安县| 乐东| 涞水县| 拜泉县| 独山县| 松溪县| 城口县| 大余县| 永登县| 伊吾县| 庆阳市| 巢湖市| 庆元县| 田林县| 正镶白旗| 西宁市| 广东省| 广昌县| 西平县|