Tomcat系列(一)- 整體架構

来源:https://www.cnblogs.com/JimmyThomas/archive/2019/12/21/12078736.html
-Advertisement-
Play Games

整體架構 我們想要瞭解一個框架,首先要瞭解它是乾什麼的,Tomcat我們都知道,是用於處理連接過來的Socket請求的。那麼Tomcat就會有兩個功能: 對外處理連接,將收到的位元組流轉化為自己想要的Request和Response對象 對內處理Servlet,將對應的Request請求分發到相應的S ...


整體架構

  我們想要瞭解一個框架,首先要瞭解它是乾什麼的,Tomcat我們都知道,是用於處理連接過來的Socket請求的。那麼Tomcat就會有兩個功能:

    • 對外處理連接,將收到的位元組流轉化為自己想要的Request和Response對象
    • 對內處理Servlet,將對應的Request請求分發到相應的Servlet中

  那麼我們整體的骨架就出來了,Tomcat其實就分為兩大部分,一部分是連接器(Connnector)處理對外連接和容器(Container)管理對內的Servelet。

  大體的關係圖如下:

  

  描述:

    最外層的大框就是代表一個Tomcat服務,一個Tomcat服務可以對應多個Service。每個Service都有連接器和容器。

    這些對應的關係我們也可以打開在Tomcat目錄配置文件中 server.xml中看出來。

<Server port="8006" shutdown="SHUTDOWN">  
    <Service name ="Catalina">    
        <Connector port ="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/>     
        <Connector port="8010" protocol="AJP/1.3" redirectPort="8443"/>
        <Engine name="Catalina" defaultHost="localhost">
            <Realm className="org.apache.catalina.realm.LockOutRealm">            
                <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
            </Realm>          
            <Host name="localhost" appBase="webapps"></Host>
        </Engine>
    </Service>    
</Server>
View Code

  這裡我們可以看到連接器其實就是 Connector,一個Service中可以有多個連接器,容器其實對應的就是 Engine

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

連接器

  我們可以看到上圖中連接器傳給容器的是 ServletRequest對象,而容器傳給連接器的是 ServletResponse對象,這些在網路傳輸過程中是肯定不行的,因為網路傳輸中傳送的位元組流。

  所以連接器的功能需求我們大概能總結出來以下幾點。

    • Socket連接
    • 讀取請求網路中的位元組流
    • 根據相應的協議(Http/AJP)解析位元組流,生成統一的 TomcatRequestt對象
    • 將 TomcatReques傳給容器
    • 容器返回 TomcatResponse對象
    • 將 TomcatResponse對象轉換為位元組流
    • 將位元組流返回給客戶端

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

    • 網路通信
    • 應用層協議的解析
    • Tomcat的 Request/Response與 ServletRequest/ServletResponse對象的轉化

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

    • EndPoint
    • Processor
    • Adapter

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

   

容器

  容器,顧名思義就是裝東西的器具,那麼這個Tomcat容器是裝什麼的呢?其實主要的就是裝了Servlet的。

  那麼容器是如何設計的呢?Tomcat的容器設計其實是用了組合設計模式(不瞭解組合設計模式的可以看我之前的文章不學無數——組合模式)。

  其實從 Server.xml中我們也能看到其關係了。

<Engine name="Catalina" defaultHost="localhost">
    <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"></Host>
</Engine>
View Code

  在這裡面我們只能看到容器中的兩個模塊,一個是頂層模塊 Engine,另一個是 Host

  其實還有兩個模塊:

    一個是 Context對應的是我們webapp裡面的每個應用文件夾,每個文件夾就是對應一個 Context

    還有一個模塊 Wrapper對應的是我們 Context中的所有servlet, Wrapper管理了訪問關係與具體的Servlet的對應。圖表示就是下麵這樣。

  

  Tomcat中容器所有模塊都實現了 Container介面,而組合模式的意義就是使得用戶對於單個對象和組合對象的使用具有一致性,

  即無論添加多少個 Context其使用就是為了找到其下麵的Servlet,而無論添加多少個Host也是為了找個下麵的Servlet。

  而在容器中設計了這麼多的模塊,一個請求過來Tomcat如何找到對應的Servlet進行處理呢?

請求如何定位

  我們就舉個最簡單的例子,我們本機應用上啟動了一個Tomcat,webapp下有我們部署的一個應用 buxuewushu

  我們在瀏覽器上輸入 http://localhost:8080/buxuewushu/add.do是如何找到對應Servlet進行處理呢?

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

    • 請求發送到本機的8080埠,被在那裡監聽的HTTP/1.1的連接器Connector獲得
    • 連接器Connector將位元組流轉換為容器所需要的 ServletRequest對象給同級 Service下的容器模塊Engine進行處理
    • Engine獲得地址 http://localhost:8080/buxuewushu/add。匹配他下麵的Host主機
    • 匹配到名為localhost的Host(就算此時請求為具體的ip,沒有配置相應的Host,也會交給名為localhost的Host進行處理,因為他是預設的主機)
    • Host匹配到路徑為 /buxuewushu的Context,即在webapp下麵找到相應的文件夾
    • Context匹配到URL規則為*.do的servlet,對應為某個Servlet類
    • 調用其 doGet或者 doPost方法
    • Servlet執行完以後將對象返回給Context
    • Context返回給Host
    • Host返回給Engine
    • Engine返回給連接器Connector
    • 連接器Connector將對象解析為位元組流發送給客戶端

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.圖片向下撐大3像素問題 在一個盒子裡面放一張圖片,預設情況下,圖片會向下撐大3像素,有以下幾種解決方法: 1.1 給圖片添加display:block; 1.2 給圖片添加 float:left; 1.3 給圖片添加 vertical-align:middle; 1.4 給他的父元素加font- ...
  • 大白話簡單工廠模式 (Simple Factory Pattern) 從買車經歷說起 畢業兩年,碼農張小兩口無法忍受擠公交,凌晨起床搶火車票的痛苦,遂計劃買車。逛了多家4S店,最終定下日產某車型的轎車。4S店接受訂單後,向工廠說明車型,工廠隨後進行汽車製造,運輸到4S店中再到了小兩口的手上,小兩口終 ...
  • 本書內容 本書從書名就可以看出來,講了架構的兩個東西,一個是原理,一個是案例。 案例部分沒有在導圖中體現,不過建議讀者還是要看一下案例,能夠通過案例對原理有更加深刻的印象 推薦程度 4.5 顆星 推薦原因 通讀本書,能對大型網站有更加直觀的感受 細節之處,能夠指導你設計網站架構選用的具體方案 即使以 ...
  • 運算符 目標 算數運算符 比較(關係)運算符 邏輯運算符 賦值運算符 運算符的優先順序 數學符號錶鏈接: "https://zh.wikipedia.org/wiki/數學符號表" 01. 算數運算符 是完成基本的算術運算使用的符號,用來處理四則運算 | 運算符 | 描述 | 實例 | | : : | ...
  • 判斷(if)語句 目標 開發中的應用場景 if 語句體驗 if 語句進階 綜合應用 01. 開發中的應用場景 生活中的判斷幾乎是無所不在的,我們每天都在做各種各樣的選擇,如果這樣?如果那樣?…… 程式中的判斷 判斷的定義 如果 條件滿足 ,才能做某件事情, 如果 條件不滿足 ,就做另外一件事情,或者 ...
  • 變數的命名 目標 標識符和關鍵字 變數的命名規則 0.1 標識符和關鍵字 1.1 標識符 標示符就是程式員定義的 變數名 、 函數名 名字 需要有 見名知義 的效果,見下圖: 標示符可以由 字母 、 下劃線 和 數字 組成 不能以數字開頭 不能與關鍵字重名 思考:下麵的標示符哪些是正確的,哪些不正確 ...
  • 變數的基本使用 程式就是用來處理數據的,而變數就是用來存儲數據的 目標 變數定義 變數的類型 變數的命名 01. 變數定義 在 Python 中,每個變數 在使用前都必須賦值 ,變數 賦值以後 該變數 才會被創建 等號(=)用來給變數賦值 左邊是一個變數名 右邊是存儲在變數中的值 變數定義之後,後續 ...
  • 一、處理異常的第二種方法 1.try......catch... 語法: try{ 可能出現異常的代碼; }catch{ 處理異常的代碼; }catch{ 註意: (1)引入了什麼異常,catch裡面就要寫清楚,出現了什麼異常該怎麼辦; (2)異常也可以有父類和子類,按照從上到下的順序進行捕捉;因此 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...