• <rt id="2wkqu"><small id="2wkqu"></small></rt>
  • 您當前的位置 :環(huán)球傳媒網(wǎng)>資訊 > 正文
    環(huán)球熱點!tomcat虛擬主機有什么用?Tomcat的請求處理過程是怎樣的?
    2022-11-21 10:15:35 來源:環(huán)球傳媒網(wǎng) 編輯:

    在生活中,很多人都不知道tomcat虛擬主機(tomcat虛擬主機有什么用)是什么意思,其實他的意思是非常簡單的,下面就是小編搜索到的tomcat虛擬主機(tomcat虛擬主機有什么用)相關(guān)的一些知識,我們一起來學(xué)習下吧!

    tomcat虛擬主機(tomcat虛擬主機有什么用)


    (相關(guān)資料圖)

    Tomcat組件

    Server和Service

    Tomcat中Server是最頂級的組件,它代表Tomcat的運行實例,一個JVM中只會包含一個Server。為了方便擴展,Server中引入了監(jiān)聽器Listener組件;為了方便集成JNDI,引入了GlobalNamingResources組件。Server中最重要的組件還是Service。

    一個Server包括多個Service

    在Tomcat中,Service組件是服務(wù)的抽象,一個Server中可以包含多個Service。Service組件負責從接收客戶端請求到處理請求的整個過程,內(nèi)部包含了若干接收客戶端消息的 Connector 組件和一個處理請求的 Engine 組件。

    此外,Service組件還包含了Executor組件,每一個Executor都是一個線程池,它可以為Service內(nèi)其他組件提供執(zhí)行任務(wù)的線程資源。

    Connector

    Tomcat的核心可以認為主要由連接器(Connector)組件和容器(Container)組件組成,其中Connector負責處理客戶端連接,而Container則負責對請求進行邏輯處理,并把結(jié)果返回給客戶端。

    不同Connect對應(yīng)不同的通信協(xié)議

    Connector主要的職責就是接收客戶端連接并接收消息報文,消息報文經(jīng)由它解析后送往容器中處理。因為Tomcat支持不同的通信協(xié)議,例如HTTP協(xié)議、AJP(Apache JServ Protocol)協(xié)議等,所以需要不同的Connector組件,每種協(xié)議對應(yīng)一個Connector組件。

    另外不同類型的網(wǎng)絡(luò)I/O,Connector組件的內(nèi)部實現(xiàn)也不相同,可分為阻塞I/O和非阻塞I/O。以HTTP協(xié)議為例,看看阻塞I/O和非阻塞I/O的Connector內(nèi)部實現(xiàn)有何不同。

    BIO Connector

    BIO Connector組件

    阻塞I/O的Connector主要由三個組件組成:

    Http11Protocol組件,是HTTP協(xié)議1.1版本的抽象,主要包含JIoEndpoint組件和Http11Processor組件。Tomcat啟動時,JIoEndpoint內(nèi)部的Acceptor開始監(jiān)聽某個端口,一個請求到來后將被扔進線程池Executor,由線程池進行任務(wù)處理。處理過程主要是通過Http11Processor組件對HTTP協(xié)議解析并傳遞到Engine容器。

    Mapper組件,負責對客戶端請求進行路由,即通過請求地址找到對應(yīng)的Servlet。

    CoyoteAdaptor組件,將Connector和Container適配起來的適配器。

    NIO Connector

    非阻塞I/O的Connector的結(jié)構(gòu)類似BIO Connector,主要區(qū)別在于:

    Http11Protocol組件改成Http11NioProtocol組件;JIoEndpoint組件改成NioEndpoint;Http11Processor組件改成Http11NioProcessor組件,功能基本類似。

    增加了一個Poller組件,負責輪詢多個客戶端連接,不斷檢測各個連接是否有可讀數(shù)據(jù),如果有客戶端可讀,則嘗試進行讀取并解析消息報文。

    Container

    Tomcat內(nèi)部有4個級別的容器,分別是Engine、Host、Context和Wrapper。Engine代表全局Servlet引擎,每個Service組件只能包含一個Engine容器組件,但Engine組件可以包含若干Host 容器組件。

    Tomcat容器

    Engine

    除了Host以外,Engine容器還包括了Engine容器級別的Listener組件(監(jiān)聽器)、AccessLog組件(日志)、Cluster組件(集群功能)、Pipeline組件(請求處理管道)、Realm組件(用戶權(quán)限)。

    Host

    Host組件代表虛擬主機的抽象,一個虛擬主機中可以存放若干Web應(yīng)用的抽象,即一個Host可以包含多個Context容器。

    和Engine類似,Host容器中也包含了Listener、AccessLog、Cluster、Pipeline、Realm這些組件,不過這些組件都是Host容器級別的。

    Context

    Context組件是Web應(yīng)用的抽象,我們開發(fā)的Web應(yīng)用部署到Tomcat后運行時就會生成一個Context對象。

    Context包含了應(yīng)用級別的Listener、AccessLog、Pipeline、Realm組件,還包括了Loader組件(加載web應(yīng)用資源)、Manager組件(會話管理)、NamingResource住院(命名資源)、Mapper組件(Servlet映射器)和Wrapper容器。

    Wrapper

    Wrapper容器是Tomcat中4個級別的容器中最小的,與之相對應(yīng)的是Servlet,一個Wrapper對應(yīng)一個Servlet。

    Wrapper中包含的組件有Servlet、ServletPool(Servlet對象池)和Pipeline組件(處理管道)。

    Tomcat的請求處理過程

    一個客戶端請求到達Tomcat之后的處理流程如上圖所示:

    當Tomcat啟動后,Connector的接收器Acceptor會監(jiān)聽是否有客戶端連接。

    一旦監(jiān)聽到客戶端連接,則將連接交給線程池Executor,開始執(zhí)行請求響應(yīng)任務(wù)。

    Http11Processor負責從客戶端連接中讀取Http報文并進行解析,解析后的報文封裝成Request對象。

    Maper根據(jù)Http協(xié)議請求的URL值和Host屬性匹配由哪個Host、哪個Context和哪個Wrapper容器來處理請求。

    CoyoteAdaptor負責將Connector組件和Engine容器連接起來,將Request對象和Response對象傳遞到Engine容器中。

    Engine容器的請求處理管道開始工作,管道里包括若干Valve,每個Valve都負責一些處理邏輯。

    Engine容器的請求處理管道工作完成后,再依次交給Host容器的處理管道、Context容器的處理管道和Wrapper容器的處理管道。最后將結(jié)果輸出到客戶端。

    參考資料:《Tomcat內(nèi)核設(shè)計剖析》

    我會持續(xù)更新關(guān)于物聯(lián)網(wǎng)、云原生、數(shù)字化技術(shù)方面的文章,用簡單的語言描述復(fù)雜的技術(shù),也會偶爾發(fā)表一下對IT產(chǎn)業(yè)的看法,請大家多多關(guān)注,歡迎留言和轉(zhuǎn)發(fā),希望與大家互動交流,謝謝。

    關(guān)鍵詞: tomcat虛擬主機 tomcat虛擬主機有什么用

    相關(guān)閱讀
    分享到:
    版權(quán)和免責申明

    凡注有"環(huán)球傳媒網(wǎng)"或電頭為"環(huán)球傳媒網(wǎng)"的稿件,均為環(huán)球傳媒網(wǎng)獨家版權(quán)所有,未經(jīng)許可不得轉(zhuǎn)載或鏡像;授權(quán)轉(zhuǎn)載必須注明來源為"環(huán)球傳媒網(wǎng)",并保留"環(huán)球傳媒網(wǎng)"的電頭。

    Copyright ? 1999-2017 cqtimes.cn All Rights Reserved 環(huán)球傳媒網(wǎng)-重新發(fā)現(xiàn)生活版權(quán)所有 聯(lián)系郵箱:8553 591@qq.com
    久久激情五月网站,一本色道综合亚洲精品精品,午夜电影久久久久久,中文无码AV片在线 成a在线观看视频播放 婷婷色中文在线观看
  • <rt id="2wkqu"><small id="2wkqu"></small></rt>