EJB技術(shù)有賴于2種重要技術(shù)的存在:Java RMI-IIOP和JNDI.EJB客戶僅僅同其暴露的單一接口進(jìn)行交互。其中暴露的接口
和企業(yè)Bean本身必須遵循EJB規(guī)范。EJB規(guī)范要求企業(yè)Bean暴露若干所要求的方法,而這些暴露的方法是供EJB容器統(tǒng)一管理他
們使用的,無(wú)論EJB組件部署在何種EJB容器中。
EJB2.1規(guī)范定義了3種EJB組件類型。
會(huì)話Bean:會(huì)話Bean用于建模業(yè)務(wù)過(guò)程。即為完成某些任務(wù)而存在。
實(shí)體Bean:實(shí)體Bean用于建模業(yè)務(wù)數(shù)據(jù)。他們是數(shù)據(jù)對(duì)象。實(shí)體Bean是用于緩存數(shù)據(jù)庫(kù)信息的Java對(duì)象。
消息驅(qū)動(dòng)Bean:MDB類似于會(huì)話Bean,因?yàn)樗鼈兌际菫橥瓿赡承┤蝿?wù)而存在的。
EJB組件是基于分布式對(duì)象構(gòu)建的,遠(yuǎn)程系統(tǒng)能夠調(diào)用分布式對(duì)象。當(dāng)然,進(jìn)程內(nèi)的客戶、進(jìn)程外的客戶及網(wǎng)絡(luò)中的其他
客戶都能夠與分布式對(duì)象進(jìn)行交互。具體過(guò)程如下:
客戶調(diào)用存根:即為客戶端提供的代理對(duì)象。存根負(fù)責(zé)將網(wǎng)絡(luò)通信屏蔽掉,這對(duì)于客戶而言意義深遠(yuǎn)。存根能夠使用
Socket訪問(wèn)網(wǎng)絡(luò)中的其他資源,其間將調(diào)用所需的參數(shù)構(gòu)建成網(wǎng)絡(luò)要求的調(diào)用格式。
借助于網(wǎng)絡(luò):存根能夠?qū)崿F(xiàn)與服務(wù)器端的骨架進(jìn)行交互。骨架是為服務(wù)器端提供的代理對(duì)象。骨架負(fù)責(zé)將網(wǎng)絡(luò)通信屏蔽
掉,這對(duì)于分布式對(duì)象而言意義深遠(yuǎn)。骨架能夠處理來(lái)自Socket的訪問(wèn)請(qǐng)求。當(dāng)然,骨架還能夠?qū)⒋娓鶚?gòu)建好的參數(shù)轉(zhuǎn)換成
Java表示。
骨架將具體的客戶調(diào)用委派給合適的分布式對(duì)象實(shí)現(xiàn)。因此,該對(duì)象將完成具體的訪問(wèn)請(qǐng)求,并將結(jié)果返回給骨架。依
此類推,骨架將結(jié)果返回給存根,最后客戶將獲得分布式對(duì)象的響應(yīng)結(jié)果(通過(guò)存根獲得)。
重要:存根和服務(wù)器端實(shí)現(xiàn)的對(duì)象都實(shí)現(xiàn)了同一接口(稱之為遠(yuǎn)程接口)。其意味著存根克隆了分布式對(duì)象的方法簽名。
調(diào)用存根中的方法的客戶以為其自身直接調(diào)用了分布式對(duì)象,但實(shí)際情況是客戶直接調(diào)用存根,而存根處理具體的網(wǎng)絡(luò)訪問(wèn)
工作。因此,這可以稱之為分布透明性。
分布式對(duì)象是對(duì)如下幾個(gè)協(xié)作對(duì)象的一種抽象:存根、骨架、實(shí)現(xiàn)的對(duì)象,單一的參與者不可能構(gòu)成分布式對(duì)象。
分布式對(duì)象是很誘人的,因?yàn)殚_發(fā)者能夠基于網(wǎng)絡(luò)構(gòu)建應(yīng)用。在開發(fā)大型的分布式對(duì)象應(yīng)用的時(shí)候,需要借助于中間件
服務(wù),如事務(wù)和安全性。
遠(yuǎn)程對(duì)象:
(1)、企業(yè)Bean的業(yè)務(wù)邏輯需要在Bean類中實(shí)現(xiàn)。EJB規(guī)范定義了企業(yè)Bean類待實(shí)現(xiàn)的若干接口。這些接口使得所有的企
業(yè)Bean類能夠暴露同一套接口。各種企業(yè)Bean的Bean類都需要實(shí)現(xiàn)javax.ejb.EnterpriseBean接口。
當(dāng)然,EJB規(guī)范分別為會(huì)話Bean、實(shí)體Bean和消息驅(qū)動(dòng)Bean提供了更專屬的接口類型,
SessionBean,EntityBean,MessageDriverBean.
(2)、當(dāng)客戶使用企業(yè)Bean類的某實(shí)例時(shí),它并不是直接調(diào)用Bean類的方法,EJB容器將攔截客戶調(diào)用,然后委派給企業(yè)
Bean實(shí)例。通過(guò)攔截客戶請(qǐng)求,EJB容器能夠自動(dòng)操作隱式中間件服務(wù)。
因此,在客戶和EJB組件間,引入了間接層,即EJB容器。引入的間接層將自身封裝為單一的網(wǎng)絡(luò)使能對(duì)象,即EJB對(duì)象,
EJB對(duì)象正是請(qǐng)求攔截器。EJB對(duì)象是代理對(duì)象,它可以與網(wǎng)絡(luò)、事務(wù)、安全性等進(jìn)行交互。企業(yè)Bean客戶調(diào)用EJB對(duì)象提供的
方法,而不是企業(yè)Bean本身。因此,EJB對(duì)象必須復(fù)制企業(yè)Bean類暴露的業(yè)務(wù)方法。但是,自動(dòng)生成EJB對(duì)象的工具是怎么知
道業(yè)務(wù)方法的呢?答案是,通過(guò)企業(yè)Bean提供者提供的接口來(lái)實(shí)現(xiàn),即遠(yuǎn)程接口。這個(gè)接口復(fù)制企業(yè)Bean類暴露的業(yè)務(wù)方法。
EJB容器負(fù)責(zé)管理EJB組件,通過(guò)調(diào)用EJB組件提供的回調(diào)方法,EJB容器能夠同EJB組件交互。這些回調(diào)方法僅供EJB容器管理
EJB組件使用。
EJB容器最為重要的一項(xiàng)工作是,提供EJB組件運(yùn)行的環(huán)境。EJB容器宿主了EJB組件,從而供遠(yuǎn)程客戶調(diào)用。因此,可以
認(rèn)為EJB容器充當(dāng)了客戶和EJB組件的中間人。EJB容器負(fù)責(zé)將客戶連接到EJB組件,完成事務(wù)協(xié)調(diào)工作,提供持久化能力,管
理EJB組件的聲明周期及其他任務(wù)。
EJB的遠(yuǎn)程接口還需復(fù)制企業(yè)Bean類的業(yè)務(wù)方法。一旦企業(yè)Bean客戶調(diào)用業(yè)務(wù)方法,EJB對(duì)象將把調(diào)用操作委派給相應(yīng)的
Bean類。
(3)、Java RMI-IIOP和EJB對(duì)象:javax.ejb.EJBObject繼承于java.rmi.Remote.任何實(shí)現(xiàn)了Remote接口的對(duì)象都是遠(yuǎn)程
對(duì)象,即能夠從其他JVM中訪問(wèn)到它,這就是Java實(shí)現(xiàn)RMI方式。由于容器提供的EJB對(duì)象實(shí)現(xiàn)了EJB組件的遠(yuǎn)程接口,因此EJB
對(duì)象也間接實(shí)現(xiàn)了java.rmi.Remote接口。EJB對(duì)象是具有完整網(wǎng)絡(luò)功能的RMI-IIOP對(duì)象,供其他JVM或者網(wǎng)絡(luò)中其他物理機(jī)器
訪問(wèn)。實(shí)際上,EJB遠(yuǎn)程接口僅僅是RMI-IIOP遠(yuǎn)程接口,只不過(guò)它還遵循EJB規(guī)范罷了。
遠(yuǎn)程接口還必須遵從RMI-IIOP的參數(shù)傳遞約定。并不是所有的內(nèi)容都能夠跨越JVM傳遞的。方法中傳遞的參數(shù)必須是符合
RMI-IIOP約定的有效Java類型,如Java原型、序列化對(duì)象和RMI-IIOP對(duì)象。
總之,EJB容器需要負(fù)責(zé)權(quán)衡資源管理和管理已部署EJB組件的生命周期。
posted on 2009-10-28 15:39
王永慶 閱讀(263)
評(píng)論(0) 編輯 收藏 所屬分類:
EJB學(xué)習(xí)筆記