關(guān)于EJB詳細(xì)概述(上)
Java EJB詳細(xì)概述 詳細(xì)概述,為什么使用EJB容器?
EJB的體系結(jié)構(gòu):
EJB的上層的分布式應(yīng)用程序是基于對(duì)象組件模型的,低層的事務(wù)服務(wù)用了API技術(shù)。EJB技術(shù)簡化了用 JAVA語言編寫的企業(yè)應(yīng)用系統(tǒng)的開發(fā),配置,和執(zhí)行。EJB的體系結(jié)構(gòu)的規(guī)范由Sun Microsystems公司制定。 Inprise的EJB容器是基于1.1版的規(guī)范。
EJB技術(shù)定義了一組可重用的組件:Enterprise Beans。你可以利用這些組件,象搭積木一樣的建立你的 分布式應(yīng)用程序。當(dāng)你把代碼寫好之后,這些組件就被組合到特定的文件中去。每個(gè)文件有一個(gè)或多個(gè) Enterprise Beans,在加上一些配置參數(shù)。***,這些Enterprise Beans被配置到一個(gè)裝了EJB容器的平臺(tái)上 ??蛻裟軌蛲ㄟ^這些Beans的home接口,定位到某個(gè)beans,并產(chǎn)生這個(gè)beans的一個(gè)實(shí)例。這樣,客戶就能夠 調(diào)用Beans的應(yīng)用方法和遠(yuǎn)程接口。
EJB服務(wù)器作為容器和低層平臺(tái)的橋梁管理著EJB容器和函數(shù)。它向EJB容器提供了訪問系統(tǒng)服務(wù)的能力。 例如:數(shù)據(jù)庫的管理和事務(wù)的管理,或者對(duì)于其它的Enterprise的應(yīng)用服務(wù)器。
所有的EJB 實(shí)例都運(yùn)行在EJB容器中。容器提供了系統(tǒng)級(jí)的服務(wù),控制了EJB的生命周期。因?yàn)槿萜髡莆樟?絕大多數(shù)系統(tǒng)級(jí)的issues(呵呵,不知道怎么翻譯)。Enterprise Beans 的開發(fā)者不需要應(yīng)用邏輯考慮進(jìn)來。 通常來說,EJB容器掌握了以下的系統(tǒng)級(jí)issues.
1、Security--配置描述器(The Deployment descriptor)定義了客戶能夠訪問的不同的應(yīng)用函數(shù)。容器 通過只允許授權(quán)的客戶訪問這些函數(shù)來達(dá)到這個(gè)效果。
2、Remote Connectivity--容器為遠(yuǎn)程鏈接管理著低層的通信issues,而且對(duì)Enterprise Beas的開發(fā)者 和客戶都隱藏了通信issues.Enterprise Beans的開發(fā)者在編寫應(yīng)用方法的時(shí)候,就象是在條用本地的平臺(tái)一 樣的??蛻粢膊磺宄麄冋{(diào)用的方法可能是在遠(yuǎn)程被處理的。
3、Life Cycle managment--客戶簡單的創(chuàng)建一個(gè)Enterprise beans的實(shí)例,并通常取消一個(gè)實(shí)例。而容 器管理著Enterprise Beans的實(shí)例,使Enterprise Beans實(shí)現(xiàn)***的效能和內(nèi)存利用率。容器能夠這樣來激 活和去活Enterprise Beans,保持眾多客戶共享的實(shí)例池。等等。
4、Trasction management—配置描述器定義了Enterprise beans 的事務(wù)處理的需求。容器管理著那些管 理分布式事務(wù)處理的復(fù)雜的issues。這些事務(wù)可能要在不同的平臺(tái)之間更新數(shù)據(jù)庫。容器使這些事務(wù)之間互 相獨(dú)立,互不干擾。保證所有的更新數(shù)據(jù)庫都是成功發(fā)生的,否者,就回滾到事務(wù)處理之前的狀態(tài)。
Enterprise Beans 組件:
Enterprise Beans 是基于分布式事務(wù)處理的企業(yè)級(jí)應(yīng)用程序的組件。所有的Enterprise beans都有如下 的特點(diǎn):
Enterprise beans包含了處理企業(yè)數(shù)據(jù)的應(yīng)用邏輯。
Enterprise beans provider定義了Enterprise beans的客戶界面(Enterprise beans 的遠(yuǎn)程界面)。這樣的界面不受容器和服務(wù)器的影響。于是,當(dāng)一個(gè) Enterprise beans被集合到一個(gè)應(yīng)用程序中去時(shí),不用更改代碼和重新編譯。
Enterprise beans能夠被 定制
各種系統(tǒng)級(jí)的服務(wù),例如安全和事務(wù)處理的特性,都不是屬于Enterprise beans class的。而是由 配置和組裝應(yīng)用程序的工具來實(shí)現(xiàn)。
有兩種類型的Enterprise beans: Session beans 和 entity beans.
Session beans:
Session beans 是一種作為單個(gè)的client執(zhí)行的對(duì)象。作為對(duì)遠(yuǎn)程的任務(wù)請(qǐng)求的相應(yīng),容器產(chǎn)生一個(gè) Session beans 的實(shí)例。一個(gè)Session beans有一個(gè)client.從某種程度上來說,一個(gè)Session bean 對(duì)于服務(wù) 器來說就代表了它的那個(gè)client.Session beans 也能用于事務(wù),它能夠更新共享的數(shù)據(jù),但它不直接描繪這 些共享的數(shù)據(jù)。
Session beans 的生命周期是相對(duì)較短的。典型的是,只有當(dāng)client保持會(huì)話的時(shí)候,Session beans 才 是活著的。一旦client退出了,Session beans 就不再與client相聯(lián)系了。Session beans被看成是瞬時(shí)的, 因?yàn)槿绻萜鞅罎⒘?,那么client必須重新建立一個(gè)新的Session對(duì)象來繼續(xù)會(huì)話。
一個(gè)Session bean典型的聲明了與client的互操作或者會(huì)話。也就是說,Session bean了在客戶會(huì)話期間 ,通過方法的調(diào)用,掌握Client的信息。一個(gè)具有狀態(tài)的Session bean稱為有狀態(tài)的Session bean.當(dāng)client 終止與Session beans互操作的時(shí)候.會(huì)話終止了,而且,bean 也不再擁有狀態(tài)值。
一個(gè)Session bean也可能是一個(gè)無狀態(tài)的 session bean.無狀態(tài)的Session beans并不掌握它的客戶的信 息或者狀態(tài)。Client能夠調(diào)用beans的方法來完成一些操作。但是,beans只是在方法調(diào)用的時(shí)候才知道 client的參數(shù)變量。當(dāng)方法調(diào)用完成以后,beans并不繼續(xù)保持這些參數(shù)變量。這樣,所有的無狀態(tài)的 session beans的實(shí)例都是相同的,除非它正在方法調(diào)用期間。這樣,無狀態(tài)的Session beans就能夠支持多 個(gè)client.容器能夠聲明一個(gè)無狀態(tài)的Session beans.能夠?qū)⑷魏蜸ession beans指定給任何client.
Entity Beans:
Entity Beans對(duì)數(shù)據(jù)庫中的數(shù)據(jù)提供了一種對(duì)象的視圖。例如:一個(gè)Entity bean能夠模擬數(shù)據(jù)庫表中一 行相關(guān)的數(shù)據(jù)。多個(gè)client能夠共享訪問同一個(gè)Entity bean.多個(gè)client也能夠同時(shí)的訪問同一個(gè)Entity bean.Entity beans通過事務(wù)的上下文來訪問或更新下層的數(shù)據(jù)。這樣,數(shù)據(jù)的完整性就能夠被保證。
Entity Beans能存活相對(duì)教長的時(shí)間,并且狀態(tài)是持續(xù)的。只要數(shù)據(jù)庫中的數(shù)據(jù)存在,Entity beans就一 直存活。而不是按照應(yīng)用程序或者服務(wù)進(jìn)程來說的。即使EJB容器崩潰了,Entity beans也是存活的。Entity Beans生命周期能夠被容器或者 Beans自己管理。如果由容器控制著保證 Entity beans持續(xù)的issus。如果由 Beans自己管理,就必須寫Entity beans的代碼,包括訪問數(shù)據(jù)庫的調(diào)用。
Entity Beans是由主鍵(primary key 一種唯一的對(duì)象標(biāo)識(shí)符)標(biāo)識(shí)的。通常,主鍵與標(biāo)識(shí)數(shù)據(jù)庫中的一 塊數(shù)據(jù),例如一個(gè)表中的一行,的主鍵是相同的。主鍵是client能夠定位特定的數(shù)據(jù)塊。
EJB roles:
EJB體系結(jié)構(gòu)通過把編程的過程分為6個(gè)不同的角色而使開發(fā)復(fù)雜的的應(yīng)用系統(tǒng)變的簡單。6個(gè)不同的角色 ,每個(gè)都有特定的任務(wù)。6個(gè)角色包括下層的服務(wù),應(yīng)用程序的開發(fā),配置和操作說明(issues)
EJB體系結(jié)構(gòu)能夠簡化應(yīng)用程序開發(fā)人員的工作。在EJB體系結(jié)構(gòu)中,容器和代理服務(wù)承擔(dān)了很多在其他環(huán) 境中又程序設(shè)計(jì)人員承擔(dān)的工作。這樣的代理提供了很多原來需要程序設(shè)計(jì)人員編寫代碼的系統(tǒng)級(jí)的服務(wù)。
Infrastructure roles;(下層構(gòu)造角色)
EJB Server Providor服務(wù)提供者是典型的提供分布式低層服務(wù)的代理。EJB服務(wù)提供者提供了一個(gè)分布式 應(yīng)用程序開發(fā)者需要的平臺(tái)和設(shè)施。也提供了分布式程序的運(yùn)行時(shí)環(huán)境。
EJB Container Providor 容器提供者是分布式系統(tǒng),事務(wù)處理,安全方面的專家容器提供者提供了一個(gè) EJB的配置工具,和這些配置實(shí)例的運(yùn)行時(shí)支持。
一個(gè)容器對(duì)一個(gè)或多個(gè)EJB來說,是一個(gè)運(yùn)行時(shí)系統(tǒng)。它將Enterprise Beans和EJB服務(wù),包括事務(wù)服務(wù), 安全服務(wù),分布式網(wǎng)絡(luò)管理等膠合在一起。容器是既是一個(gè)定制的代碼和對(duì)特定的 Enterprise beans產(chǎn)生詳 細(xì)代碼的工具。容器也提供了一個(gè)配置Enterprise beans的工具和管理監(jiān)視應(yīng)用程序的方法。
【編輯推薦】