回顧Tomcat處理請(qǐng)求
下圖是對(duì)于Tomcat處理請(qǐng)求內(nèi)部的流轉(zhuǎn)過(guò)程.也描述了Tomcat組件的靜態(tài)關(guān)系.
如果讓一個(gè)系統(tǒng)能夠?qū)ν馓峁┓?wù),需要?jiǎng)?chuàng)建,組裝并啟動(dòng)這些組件,在停止的時(shí)候,需要釋放資源,銷毀組件,這個(gè)過(guò)程都是動(dòng)態(tài)的,所以Tomcat需要?jiǎng)討B(tài)管理這些組件的生命周期.
Tomcat的LifeCycle接口
在Tomcat的啟動(dòng)過(guò)程中,每個(gè)組件都要經(jīng)歷創(chuàng)建,初始化,啟動(dòng)這幾個(gè)過(guò)程,而這幾個(gè)狀態(tài)的轉(zhuǎn)變都是固定的,但是具體組件的初始化邏輯和啟動(dòng)方式都不一樣,所以Tomcat把組件的生命周期方法抽象到LifeCycle接口,讓每個(gè)具體的組件去實(shí)現(xiàn)接口的方法.
可以看到紅框內(nèi)的方法就是對(duì)組件生命周期的抽象
LifeCycle的監(jiān)聽(tīng)事件
為了解耦組件,所以LifeCycle中的方法都是由父組件進(jìn)行調(diào)用,如果要對(duì)子組件新增邏輯,就需要用到組件的狀態(tài)監(jiān)聽(tīng).
這里用到了觀察者模式.上圖中的
Listener相關(guān)方法就是監(jiān)聽(tīng)組件狀態(tài)變化的方法.LifecycleStats枚舉類定義了組件的所有狀態(tài)
在LifeCycle依賴關(guān)系中,可以看到有一個(gè)實(shí)現(xiàn)類LifeCycleBase,實(shí)現(xiàn)了LifeCycle接口的所有方法,定義了相應(yīng)的抽象方法交給子類實(shí)現(xiàn),這是經(jīng)典的模板設(shè)計(jì)模式.
LifeCycleBase的init方法
可以看到初始化方法是synchronized修飾的,證明不能多線程進(jìn)行組件的創(chuàng)建.
- 1.檢查狀態(tài)
- 2.修改狀態(tài),觸發(fā)
INITIALIZING事件監(jiān)聽(tīng)
狀態(tài)變化會(huì)通知所有的觀察者
- 3.調(diào)用子類的初始化方法
- 4.修改狀態(tài),觸發(fā)
INITIALIZED事件監(jiān)聽(tīng)
組件監(jiān)聽(tīng)器注冊(cè)方法
- Tomcat自定義的監(jiān)聽(tīng)器,這些監(jiān)聽(tīng)器是父組件在創(chuàng)建子組件的過(guò)程中注冊(cè)到子組件的.例如MemoryLeakTracingListener,用來(lái)檢測(cè)Context容器中的內(nèi)存泄漏,這個(gè)監(jiān)聽(tīng)器在Host容器創(chuàng)建Context容器時(shí)注冊(cè)到Context中的.
具體位置在StandardHost#addChild方法
- 在server.xml定義監(jiān)聽(tīng)器,Tomcat在啟動(dòng)時(shí)會(huì)解析server.xml,創(chuàng)建監(jiān)聽(tīng)器并注冊(cè)到容器組件.
ContainerBase的公共邏輯
- 1.容器的創(chuàng)建/初始化/銷毀
- 2.容器添加/刪除子容器