www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]Tomcat 支持的 io 模型有 NIO、NIO2、APR,Tomcat 支持的應(yīng)用層協(xié)議有 http1.1 ajp http2.0。Tomcat 最頂層是 server,一個(gè) server 有多個(gè) service,一個(gè) service 有多個(gè)連接器和一個(gè)容器,連接器和容器之間通過(guò) ServletRequest 和 ServletResponse 通信。



總體架構(gòu)

核心功能:
  • 處理 socket 連接,負(fù)責(zé)將網(wǎng)絡(luò)字節(jié)流與 Request 和 Response 對(duì)象的轉(zhuǎn)化;

  • 加載和管理 Servlet,以及具體處理 Request 請(qǐng)求;

Tomcat 支持的 io 模型有 NIO、NIO2、APR,Tomcat 支持的應(yīng)用層協(xié)議有 http1.1 ajp http2.0。

Tomcat 最頂層是 server,一個(gè) server 有多個(gè) service,一個(gè) service 有多個(gè)連接器和一個(gè)容器,連接器和容器之間通過(guò) ServletRequest 和 ServletResponse 通信。

牛!硬核圖解Tomcat整體架構(gòu)

通過(guò)組合模式、模板方法、觀察者模式和骨架抽象類,tomcat 定義了基類 LifeCycleBean 實(shí)現(xiàn) LifeCycle 接口,把公共的邏輯,生命周期狀態(tài)轉(zhuǎn)變和維護(hù)、生命事件的觸發(fā)和監(jiān)聽器的添加刪除,子類負(fù)責(zé)實(shí)現(xiàn)自己的 init、stop 和 start 等方法。

  • tomcat 自定義了監(jiān)聽器;
  • @WebListener 注解,定義自己的監(jiān)聽器;

StandardServer、StandardService 等是 Server 和 Service 組件的具體實(shí)現(xiàn)類,它們都繼承了 LifecycleBase。

StandardEngine、StandardHost、StandardContext 和 StandardWrapper 是相應(yīng)容器組件的具體實(shí)現(xiàn)類,因?yàn)樗鼈兌际侨萜?,所以繼承了 ContainerBase 抽象基類,而 ContainerBase 實(shí)現(xiàn)了 Container 接口,也繼承了 LifecycleBase 類,它們的生命周期管理接口和功能接口是分開的。

連接器 Connector

連接器進(jìn)一步細(xì)化:
  • 監(jiān)聽網(wǎng)絡(luò)端口;
  • 接受網(wǎng)絡(luò)請(qǐng)求;
  • 讀取網(wǎng)絡(luò)字節(jié)流;
  • 根據(jù)應(yīng)用層協(xié)議解析字節(jié)流,生成統(tǒng)一的 tomcat request 和 tomcat response 對(duì)象;
  • 將 tomcat request 對(duì)象轉(zhuǎn)成 servletRequest;
  • 調(diào)用 servlet 容器,得到 servletResponse;
  • 將 servletResponse 轉(zhuǎn)成 tomcat response;
  • 將 tomcat response 轉(zhuǎn)成網(wǎng)絡(luò)字節(jié)流;
  • 將響應(yīng)字節(jié)流寫回給瀏覽器;
按照高內(nèi)聚的功能劃分:
  • 網(wǎng)絡(luò)通信;
  • 應(yīng)用層協(xié)議解析;
  • tomcat request/response 與 servlet request/response 的轉(zhuǎn)換;

組件通過(guò)接口交互,好處是封裝變化。Endpoint 負(fù)責(zé)提供字節(jié)流給 Processor,Processor 負(fù)責(zé)提供 tomcat request 對(duì)象給 Adapter,Adapter負(fù)責(zé)提供 Servlet Request 給容器。

其中 Endpoint 和 Processor 抽象組裝在一起形成了 ProtocolHandler 組件。

牛!硬核圖解Tomcat整體架構(gòu)

ProtocolHandler

Endpoint

接口,抽象實(shí)現(xiàn)類是 AbstractEndpoint,具體子類在 NioEndpoint 和 Nio2Endpoint,其中兩個(gè)重要組件:Acceptor 和 SocketProcessor。

Acceptor 用于監(jiān)聽 Socket 連接請(qǐng)求,SocketProcessor 用于處理收到的 Socket 請(qǐng)求,提交到線程池 Executor 處理。

Processor

接收 Endpoint 的 socket,讀取字節(jié)流解析成 tomcat request 和 response,通過(guò) adapter 將其提交到容器處理。Processor 的具體實(shí)現(xiàn)類 AjpProcessor、Http11Processor 實(shí)現(xiàn)了特定協(xié)議的解析方法和請(qǐng)求處理方式。

牛!硬核圖解Tomcat整體架構(gòu)

Endpoint 接收到 socket 連接后,生成一個(gè) socketProcessor 交給線程池處理,run 方法會(huì)調(diào)用 Processor 解析應(yīng)用層協(xié)議,生成 tomcat request 后,調(diào)用 adapter 的 service 方法。

Adapter

ProtocolHandler 接口負(fù)責(zé)解析請(qǐng)求生成 tomcat requst,CoyoteAdapter 的 service 方法,將 Tomcat Request 對(duì)象,轉(zhuǎn)成 ServletRequest,再調(diào)用 service 方法。

容器 Container

容器的層次結(jié)構(gòu)

父子關(guān)系的 Engine、Host、Context、Wrapper 和 Servlet。Context 表示 web 應(yīng)用程序、wrapper 表示 servlet、context 有多個(gè) wrapper,host 也有多個(gè) context。

牛!硬核圖解Tomcat整體架構(gòu)

Host 代表的是一個(gè)虛擬主機(jī),或者說(shuō)一個(gè)站點(diǎn),可以給 Tomcat 配置多個(gè)虛擬主機(jī)地址,而一個(gè)虛擬主機(jī)下可以部署多個(gè) Web 應(yīng)用程序;Engine 表示引擎,用來(lái)管理多個(gè)虛擬站點(diǎn),一個(gè) Service 最多只能有一個(gè) Engine。

牛!硬核圖解Tomcat整體架構(gòu)

容器通過(guò) Pipeline-Valve 責(zé)任鏈,對(duì)請(qǐng)求一次處理,invoke 處理方法,每個(gè)容器都有一個(gè) Pipeline,觸發(fā)第一個(gè) Valve,這個(gè)容器的 valve 都會(huì)被調(diào)到,不同容器之間通過(guò) Pipeline 的 getBasic 方法,負(fù)責(zé)調(diào)用下層容器的第一個(gè) Valve。

牛!硬核圖解Tomcat整體架構(gòu)

整個(gè)調(diào)用連由連接器中的 adapter 觸發(fā),調(diào)用 engine 中的第一個(gè) Valve。

1//?Calling?the?container
2connector.getService().getContainer().getPipeline().getFirst().invoke(request,?response);

wrapper 容器的最后一個(gè) valve 創(chuàng)建一個(gè) filter 鏈,并調(diào)用 doFilter 方法,最終會(huì)調(diào)用到 servlet 的 service 方法。

 1final?class?StandardWrapperValve
2????extends?ValveBase?
{
3
4???@Override
5??????public?final?void?invoke(Request?request,?Response?response)
6??????????throws?IOException,?ServletException?
{
7??????????//?...
8
9??????????ApplicationFilterChain?filterChain?=
10????????????????ApplicationFilterFactory.createFilterChain(request,?wrapper,?servlet);
11
12????????//?Call?the?filter?chain?for?this?request
13????????//?NOTE:?This?also?calls?the?servlet's?service()?method
14????????Container?container?=?this.container;
15????????try?{
16????????????if?((servlet?!=?null)?&&?(filterChain?!=?null))?{
17????????????????//?Swallow?output?if?needed
18????????????????if?(context.getSwallowOutput())?{
19????????????????????try?{
20????????????????????????SystemLogHandler.startCapture();
21????????????????????????if?(request.isAsyncDispatching())?{
22????????????????????????????request.getAsyncContextInternal().doInternalDispatch();
23????????????????????????}?else?{
24
25????????????????????????//?dofilter
26????????????????????????????filterChain.doFilter(request.getRequest(),
27????????????????????????????????????response.getResponse());
28????????????????????????}
29????????????????????}?finally?{
30????????????????????????String?log?=?SystemLogHandler.stopCapture();
31????????????????????????if?(log?!=?null?&&?log.length()?>?0)?{
32????????????????????????????context.getLogger().info(log);
33????????????????????????}
34????????????????????}
35????????????????}?else?{
36????????????????????if?(request.isAsyncDispatching())?{
37????????????????????????request.getAsyncContextInternal().doInternalDispatch();
38????????????????????}?else?{
39????????????????????????//?dofilter
40????????????????????????filterChain.doFilter
41????????????????????????????(request.getRequest(),?response.getResponse());
42????????????????????}
43????????????????}
44
45????????????}
46????????}?catch()?{
47????????//?...
48????????}
49????}
50}

ServletContext 是 tomcat 中的一個(gè)成員變量,spring 中的 ApplicationContext 是 servlet 規(guī)范中的 ServletContext 屬性。

作者:rhsphere


特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

牛!硬核圖解Tomcat整體架構(gòu)

牛!硬核圖解Tomcat整體架構(gòu)

牛!硬核圖解Tomcat整體架構(gòu)

長(zhǎng)按訂閱更多精彩▼

牛!硬核圖解Tomcat整體架構(gòu)

如有收獲,點(diǎn)個(gè)在看,誠(chéng)摯感謝


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉