Tomcat是如何執行的?整體架構又是怎樣的?

2021-10-03 10:43:05 字數 2031 閱讀 6095

在許多的高階開發的崗位中都會或多或少有要求面試人員要研究過一些常用中介軟體原始碼。這是因為一切的秘密都是藏在原始碼中,閱讀原始碼能夠讓我們對框架或者中介軟體的理解更加深刻,而我們也能夠在原始碼的研究中獲得其中一些優秀的設計方式。

而我們的中介軟體和原始碼那麼多,我們該從何入手呢?其實大部分的中介軟體或者框架都有一些共性的部分,例如網路程式設計、多執行緒、反射和類載入等技術。所以深入研究透了一兩個中間價的話,那麼再回過頭來看其他的中介軟體,那麼就會很容易理解它裡面所用的技術以及原理。而作為乙個老牌的web端框架tomcat,無論是其整體的架構設計,還是其內在的一些技術靈活應用,都值得我們一看。

在學習框架的時候,我一般都是對這個框架有乙個整體的認識。知道它整體是如何執行的,然後再深入其中某部分進行研究,這樣會事半功倍。

我們想要了解乙個框架,首先要了解它是幹什麼的,tomcat我們都知道,是用於處理連線過來的socket請求的。那麼tomcat就會有兩個功能:

對外處理連線,將收到的位元組流轉化為自己想要的request和response物件

對內處理servlet,將對應的request請求分發到相應的servlet中

那麼我們整體的骨架就出來了,tomcat其實就分為兩大部分,一部分是聯結器(connnector)處理對外連線和容器(container)管理對內的servelet。大體的關係圖如下

最外層的大框就是代表乙個tomcat服務,乙個tomcat服務可以對應多個service。每個service都有聯結器和容器。這些對應的關係我們也可以開啟在tomcat目錄配置檔案中server.xml中看出來。

這裡我將其中配置檔案中刪除了一些內容精簡了一下,這裡我們可以看到聯結器其實就是connector,乙個service中可以有多個聯結器,容器其實對應的就是engine。

tomcat的整體架構簡單來說就是這樣的對應關係。接下來我們簡單的介紹聯結器的整體架構和容器的整體架構。

我們可以看到上圖中聯結器傳給容器的是servletrequest物件,而容器傳給聯結器的是servletresponse物件,這些在網路傳輸過程中是肯定不行的,因為網路傳輸中傳送的位元組流。所以聯結器的功能需求我們大概能總結出來以下幾點。

socket連線

讀取請求網路中的位元組流

根據相應的協議(http/ajp)解析位元組流,生成統一的tomcat requestt物件

將tomcat reques傳給容器

容器返回tomcat response物件

將tomcat response物件轉換為位元組流

將位元組流返回給客戶端

其實上面的細分都能總結為以下的三點

網路通訊

應用層協議的解析

tomcat的request/response與servletrequest/servletresponse物件的轉化

而在tomcat中它也用了三個類來實現上面的三個功能,分別對應如下

endpoint

processor

adapter

用圖表示他們的關係的話就是這樣

容器,顧名思義就是裝東西的器具,那麼這個tomcat容器是裝什麼的呢?其實主要的就是裝了servlet的。那麼容器是如何設計的呢?tomcat的容器設計其實是用了組合設計,其實從server.xml中我們也能看到其關係了。

tomcat中容器所有模組都實現了container介面,而組合模式的意義就是使得使用者對於單個物件和組合物件的使用具有一致性,即無論新增多少個context其使用就是為了找到其下面的servlet,而無論新增多少個host也是為了找個下面的servlet。而在容器中設計了這麼多的模組,乙個請求過來tomcat如何找到對應的servlet進行處理呢?

在我們啟動tomcat的時候,聯結器就會進行初始化監聽所配置的埠號,這裡我們配置的是8080埠對應的協議是http。

Tomcat的整體架構

tomcat通過聯結器和容器這兩個核心元件完成整體工作,聯結器負責處理socket連線和網路位元組流與request和response物件的轉化 容器負責載入和管理servlet,以及具體處理request請求。在學習tomcat整體架構前需要知道,tomcat 支援的多種 i o 模型和應用層協議...

tomcat中如何執行war包呢

示例專案 對於乙個web專案來說,我們使用ide開發完成後,如何在tomcat中執行呢,因為我們開發是使用ide,可以在ide中執行,但是實際在執行的時候 是在server.xml中進行設定 host autodeploy true name localhost unpackwars true va...

程式是如何執行的(二)控制結構的執行

一 if else選擇語句 1 分支跳轉指令 我們將用相應的彙編指令來表示 比較x是否小於y 選擇跳轉到語句塊b 1 slt指令 比較x是否小於y 格式 slt r4,r1,r2。該指令用來表示比較暫存器r1中的值是否小於r2中的值,如果小於則將暫存器r4置1,否則置0 格式 slt r4,r1,c...