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