Tomcat:設(shè)計(jì)模式用的好,下班就能早!
tomcat作為一款經(jīng)典的輕量級(jí)應(yīng)用服務(wù)器,自然也使用了很多優(yōu)雅的設(shè)計(jì)模式。
今天給大家簡單介紹一下tomcat在初始化組件時(shí)使用的幾種設(shè)計(jì)模式。
tomcat大體上的架構(gòu)
組合模式
在tomcat中,把不同的功能設(shè)計(jì)為了不同的組件,比如connector、engine、host、context等。那么在tomcat啟動(dòng)時(shí),這些組件是如何被一一啟動(dòng)的呢?
我們?cè)谠创a中查看這些組件時(shí),可以發(fā)現(xiàn)這些組件都實(shí)現(xiàn)了Lifecycle接口。
從名字就可以看出,這個(gè)接口是用來管理生命周期的。
tomcat通過Lifecycle接口來組合裝載各個(gè)組件。比如在一個(gè)父組件中,需要調(diào)用某個(gè)子組件時(shí),就在init方法調(diào)用子組件的init,在start方法中調(diào)用子組件的start。
這樣的好處在于父組件可以根據(jù)業(yè)務(wù)需要隨意組合子組件,并且在父組件中不用硬編碼的去構(gòu)建子組件的對(duì)象,子組件的初始化由子組件的init自己實(shí)現(xiàn)。
觀察者模式
大家有沒有發(fā)現(xiàn),如果父組件調(diào)用子組件的時(shí)候,直接調(diào)用init或者start方法,還是有點(diǎn)強(qiáng)耦合了。如果父組件要調(diào)用多個(gè)子組件的時(shí)候,是不是還得修改父組件的方法?
所以,tomcat還使用了觀察者模式,通過訂閱狀態(tài)的變化來實(shí)現(xiàn)對(duì)子組件的調(diào)用。
以初始化為例,當(dāng)?shù)谝粋€(gè)父組件初始化時(shí),會(huì)發(fā)布狀態(tài)變更事件,讓訂閱的子組件進(jìn)行相應(yīng)的初始化。
通過觀察者模式,tomcat輕松的將一連串的組件給啟動(dòng)起來了。
模板設(shè)計(jì)模式
Lifecycle接口還有兩個(gè)抽象子類,LifecycleMBeanBase和LifecycleBase。
這兩個(gè)類的作用是將一些比較有共性的方法給抽離了出來,這樣子類就不用再去重復(fù)的實(shí)現(xiàn)了。
這樣不僅保持了代碼的簡潔性,還降低了重復(fù)書寫出錯(cuò)的概率。
比如通用的init方法。
除了這三種,tomcat當(dāng)然還使用了其他的設(shè)計(jì)模式。本文是從tomcat的生命周期管理類為切入點(diǎn),為大家介紹了tomcat在管理生命周期時(shí),配合使用的幾種設(shè)計(jì)模式。
在我們?nèi)粘5木幋a工作中,通過合適的設(shè)計(jì)模式不僅可以使代碼邏輯更清晰,還可以大大降低出bug的概率,建議大家可以多多嘗試一下。