tomcat架构分析(valve机制)【转】
原文地址:https://www.iteye.com/blog/gearever-1536022
關于tomcat的內部邏輯單元的存儲空間已經在相關容器類的blog里闡述了。在每個容器對象里面都有一個pipeline及valve模塊。它們是容器類必須具有的模塊。在容器對象生成時自動產生。Pipeline就像是每個容器的邏輯總線。在pipeline上按照配置的順序,加載各個valve。通過pipeline完成各個valve之間的調用,各個valve實現具體的應用邏輯。?
先看一下pipeline及valve的邏輯概念圖。?
這些valve就是在tomcat的server.xml中配置,只要滿足一定條件,繼承ValveBase基類?
就可以在不同的容器中配置,然后在消息流中被逐一調用。每個容器的valve的作用域不一樣,在總體結構中已有說明。這里紅色標記的是配置的自定義的valve,這樣可以擴展成多個其他應用,例如cluster應用等。?
Tomcat實現?
Tomcat提供了Pipeline的標準實現:?
四大容器類StandardEngine,StandardHost,StandardContext及StandardWrapper都有各自缺省的標準valve實現。它們分別是?
- Engine:org.apache.catalina.core.StandardEngineValve
- Host: org.apache.catalina.core.StandardHostValve
- Context:org.apache.catalina.core.StandardContextValve
- Wrapper:org.apache.catalina.core.StandardWrapperValve
容器類生成對象時,都會生成一個pipeline對象,同時,生成一個缺省的valve實現,并將這個標準的valve對象綁定在其pipeline對象上。以StandardHost類為例:?
Valve實現了具體業務邏輯單元。可以定制化valve(實現特定接口),然后配置在server.xml里。每層容器都可以配置相應的valve,當只在其作用域內有效。例如engine容器里的valve只對其包含的所有host里的應用有效。定制化的valve是可選的,但是每個容器有一個缺省的valve,例如engine的StandardEngineValve,是在StandardEngine里自帶的,它主要實現了對其子host對象的StandardHostValve的調用,以此類推。?
配置的例子有:?
當在server.xml文件中配置了一個定制化valve時,會調用pipeline對象的addValve方法,將valve以鏈表方式組織起來,看一下代碼;?
從上面可以清楚的看出,valve按照容器作用域的配置順序來組織valve,每個valve都設置了指向下一個valve的next引用。同時,每個容器缺省的標準valve都存在于valve鏈表尾端,這就意味著,在每個pipeline中,缺省的標準valve都是按順序,最后被調用。?
消息流?
先看一下四大容器的標準valve的調用邏輯圖。從中可以梳理出標準valve的邏輯。注意此圖只是在缺省配置下的狀態,也就是說每個pipeline只包含一個標準valve的情況。?
圖中顯示的是各個容器默認的valve之間的實際調用情況。從StandardEngineValve開始,一直到StandardWrapperValve,完成整個消息處理過程。注意每一個上層的valve都是在調用下一層的valve返回后再返回的,這樣每個上層valve不僅具有request對象,同時還能拿到response對象,想象一下,這樣是不是可以批量的做很多東西?
轉載于:https://www.cnblogs.com/davidwang456/articles/11452722.html
總結
以上是生活随笔為你收集整理的tomcat架构分析(valve机制)【转】的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: tomcat架构分析 (connecto
- 下一篇: tomcat架构分析(valve源码导读