這篇文章主要介紹“Tomcat中門面設(shè)計模式的原理”,在日常操作中,相信很多人在Tomcat中門面設(shè)計模式的原理問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Tomcat中門面設(shè)計模式的原理”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
成都創(chuàng)新互聯(lián)專注于河南網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供河南營銷型網(wǎng)站建設(shè),河南網(wǎng)站制作、河南網(wǎng)頁設(shè)計、河南網(wǎng)站官網(wǎng)定制、微信小程序服務(wù),打造河南網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供河南網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。門面設(shè)計模式在 Tomcat 中有多處使用,在 Request 和 Response 對象封裝中、Standard Wrapper 到 ServletConfig 封裝中、ApplicationContext 到 ServletContext 封裝中等都用到了這種設(shè)計模式。
這么多場合都用到了這種設(shè)計模式,那這種設(shè)計模式究竟能有什么作用呢?顧名思義,就是將一個東西封裝成一個門面好與人家更容易進行交流,就像一個國家的外交部一樣。
這種設(shè)計模式主要用在一個大的系統(tǒng)中有多個子系統(tǒng)組成時,這多個子系統(tǒng)肯定要涉及到相互通信,但是每個子系統(tǒng)又不能將自己的內(nèi)部數(shù)據(jù)過多的暴露給其它系統(tǒng),不然就沒有必要劃分子系統(tǒng)了。每個子系統(tǒng)都會設(shè)計一個門面,把別的系統(tǒng)感興趣的數(shù)據(jù)封裝起來,通過這個門面來進行訪問。這就是門面設(shè)計模式存在的意義。
門面設(shè)計模式示意圖如下:
圖 1. 門面示意圖
Client 只能訪問到 Fa?ade 中提供的數(shù)據(jù)是門面設(shè)計模式的關(guān)鍵,至于 Client 如何訪問 Fa?ade 和 Subsystem 如何提供 Fa?ade 門面設(shè)計模式并沒有規(guī)定死。
Tomcat 中門面設(shè)計模式使用的很多,因為 Tomcat 中有很多不同組件,每個組件要相互交互數(shù)據(jù),用門面模式隔離數(shù)據(jù)是個很好的方法。
下面是 Request 上使用的門面設(shè)計模式:
圖 2. Request 的門面設(shè)計模式類圖
從圖中可以看出 HttpRequestFacade 類封裝了 HttpRequest 接口能夠提供數(shù)據(jù),通過 HttpRequestFacade 訪問到的數(shù)據(jù)都被代理到 HttpRequest 中,通常被封裝的對象都被設(shè)為 Private 或者 Protected 訪問修飾,以防止在 Fa?ade 中被直接訪問。
這種設(shè)計模式也是常用的設(shè)計方法通常也叫發(fā)布 - 訂閱模式,也就是事件監(jiān)聽機制,通常在某個事件發(fā)生的前后會觸發(fā)一些操作。
觀察者模式原理也很簡單,就是你在做事的時候旁邊總有一個人在盯著你,當你做的事情是它感興趣的時候,它就會跟著做另外一些事情。但是盯著你的人必須要到你那去登記,不然你無法通知它。觀察者模式通常包含下面這幾個角色:
Subject 就是抽象主題:它負責管理所有觀察者的引用,同時定義主要的事件操作。
ConcreteSubject 具體主題:它實現(xiàn)了抽象主題的所有定義的接口,當自己發(fā)生變化時,會通知所有觀察者。
Observer 觀察者:監(jiān)聽主題發(fā)生變化相應(yīng)的操作接口。
Tomcat 中觀察者模式也有多處使用,前面講的控制組件生命周期的 Lifecycle 就是這種模式的體現(xiàn),還有對 Servlet 實例的創(chuàng)建、Session 的管理、Container 等都是同樣的原理。下面主要看一下 Lifecycle 的具體實現(xiàn)。
Lifecycle 的觀察者模式結(jié)構(gòu)圖:
圖 3. Lifecycle 的觀察者模式結(jié)構(gòu)圖
上面的結(jié)構(gòu)圖中,LifecycleListener 代表的是抽象觀察者,它定義一個 lifecycleEvent 方法,這個方法就是當主題變化時要執(zhí)行的方法。 ServerLifecycleListener 代表的是具體的觀察者,它實現(xiàn)了 LifecycleListener 接口的方法,就是這個具體的觀察者具體的實現(xiàn)方式。Lifecycle 接口代表的是抽象主題,它定義了管理觀察者的方法和它要所做的其它方法。而 StandardServer 代表的是具體主題,它實現(xiàn)了抽象主題的所有方法。這里 Tomcat 對觀察者做了擴展,增加了另外兩個類:LifecycleSupport、LifecycleEvent,它們作為輔助類擴展了觀察者的功能。LifecycleEvent 使得可以定義事件類別,不同的事件可區(qū)別處理,更加靈活。LifecycleSupport 類代理了主題對多觀察者的管理,將這個管理抽出來統(tǒng)一實現(xiàn),以后如果修改只要修改 LifecycleSupport 類就可以了,不需要去修改所有具體主題,因為所有具體主題的對觀察者的操作都被代理給 LifecycleSupport 類了。這可以認為是觀察者模式的改進版。
LifecycleSupport 調(diào)用觀察者的方法代碼如下:
清單 1. LifecycleSupport 中的 fireLifecycleEvent 方法
1 2 3 4 5 6 7 8 9 |
|
主題是怎么通知觀察者呢?看下面代碼:
清單 2. 容器中的 start 方法
1 2 3 4 5 6 7 8 9 10 11 12 |
|
前面把 Tomcat 中兩個核心組件 Connector 和 Container,比作一對夫妻。男的將接受過來的請求以命令的方式交給女主人。對應(yīng)到 Connector 和 Container,Connector 也是通過命令模式調(diào)用 Container 的。
命令模式主要作用就是封裝命令,把發(fā)出命令的責任和執(zhí)行命令的責任分開。也是一種功能的分工。不同的模塊可以對同一個命令做出不同解釋。
下面是命令模式通常包含下面幾個角色:
Client:創(chuàng)建一個命令,并決定接受者
Command 命令:命令接口定義一個抽象方法
ConcreteCommand:具體命令,負責調(diào)用接受者的相應(yīng)操作
Invoker 請求者:負責調(diào)用命令對象執(zhí)行請求
Receiver 接受者:負責具體實施和執(zhí)行一次請求
Tomcat 中命令模式在 Connector 和 Container 組件之間有體現(xiàn),Tomcat 作為一個應(yīng)用服務(wù)器,無疑會接受到很多請求,如何分配和執(zhí)行這些請求是必須的功能。
下面看一下 Tomcat 是如何實現(xiàn)命令模式的,下面是 Tomcat 命令模式的結(jié)構(gòu)圖:
圖 4. Tomcat 命令模式的結(jié)構(gòu)圖
Connector 作為抽象請求者,HttpConnector 作為具體請求者。HttpProcessor 作為命令。Container 作為命令的抽象接受者,ContainerBase 作為具體的接受者??蛻舳司褪菓?yīng)用服務(wù)器 Server 組件了。Server 首先創(chuàng)建命令請求者 HttpConnector 對象,然后創(chuàng)建命令 HttpProcessor 命令對象。再把命令對象交給命令接受者 ContainerBase 容器來處理命令。命令的最終是被 Tomcat 的 Container 執(zhí)行的。命令可以以隊列的方式進來,Container 也可以以不同的方式來處理請求,如 HTTP1.0 協(xié)議和 HTTP1.1 的處理方式就會不同。
Tomcat 中一個最容易發(fā)現(xiàn)的設(shè)計模式就是責任鏈模式,這個設(shè)計模式也是 Tomcat 中 Container 設(shè)計的基礎(chǔ),整個容器的就是通過一個鏈連接在一起,這個鏈一直將請求正確的傳遞給最終處理請求的那個 Servlet。
責任鏈模式,就是很多對象有每個對象對其下家的引用而連接起來形成一條鏈,請求在這條鏈上傳遞,直到鏈上的某個對象處理此請求,或者每個對象都可以處理請求,并傳給下一家,直到最終鏈上每個對象都處理完。這樣可以不影響客戶端而能夠在鏈上增加任意的處理節(jié)點。
通常責任鏈模式包含下面幾個角色:
Handler(抽象處理者):定義一個處理請求的接口
ConcreteHandler(具體處理者):處理請求的具體類,或者傳給下家
在 tomcat 中這種設(shè)計模式幾乎被完整的使用,tomcat 的容器設(shè)置就是責任鏈模式,從 Engine 到 Host 再到 Context 一直到 Wrapper 都是通過一個鏈傳遞請求。
Tomcat 中責任鏈模式的類結(jié)構(gòu)圖如下:
圖 5. Tomcat 責任鏈模式的結(jié)構(gòu)圖
上圖基本描述了四個子容器使用責任鏈模式的類結(jié)構(gòu)圖,對應(yīng)的責任鏈模式的角色,Container 扮演抽象處理者角色,具體處理者由 StandardEngine 等子容器扮演。與標準的責任鏈不同的是,這里引入了 Pipeline 和 Valve 接口。他們有什么作用呢?
實際上 Pipeline 和 Valve 是擴展了這個鏈的功能,使得在鏈往下傳遞過程中,能夠接受外界的干預(yù)。Pipeline 就是連接每個子容器的管子,里面?zhèn)鬟f的 Request 和 Response 對象好比管子里流的水,而 Valve 就是這個管子上開的一個個小口子,讓你有機會能夠接觸到里面的水,做一些額外的事情。
為了防止水被引出來而不能流到下一個容器中,每一段管子最后總有一個節(jié)點保證它一定能流到下一個子容器,所以每個容器都有一個 StandardXXXValve。只要涉及到這種有鏈式是處理流程這是一個非常值得借鑒的模式。
到此,關(guān)于“Tomcat中門面設(shè)計模式的原理”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
當前文章:Tomcat中門面設(shè)計模式的原理-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://weahome.cn/article/dchiss.html