?? 第三部分:布署和使用 enterprise javabeans 組件(一)(轉).txt
字號:
作者:zergman
email: zergman@chinaasp.com
日期:6/15/2001 1:42:42 PM
[TABLE][TR][TD]什么是 Enterprise JavaBeans 組件?[/TD][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index_eng.shtml][img]http://www.cn.ibm.com/developerworks/i/src.gif[/img][/url][/TD][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][/TABLE][TABLE][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][TD][TABLE][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][TD][TABLE][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][B]內容:[/B][/TD][/TR][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][TABLE][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#0a]部署[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#0]容器服務[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#1]CORBA[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#2]使用 EJB 組件[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#3]結論[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#resources]參考資料[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part3/index.shtml#author]作者簡介[/url][/TD][/TR][/TABLE][/TD][/TR][/TABLE][TABLE][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][B]相關內容:[/B][/TD][/TR][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][TABLE][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part1/index.shtml]第一部分:EJB 體系結構的歷史和目標[/url][/TD][/TR][TR][TD][url href=http://www.cn.ibm.com/developerWorks/java/what-are-ejbs/part2/index.shtml]第二部分:編程模型[/url][/TD][/TR][/TABLE][/TD][/TR][/TABLE][TABLE][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][TR][TD][img]http://www.cn.ibm.com/developerWorks/i/c.gif[/img][/TD][/TR][/TABLE][/TD][/TR][/TABLE]第三部分:布署和使用 Enterprise JavaBeans 組件
Ken Nordby
軟件工程師,IBM
2000 年 7 月[BLOCKQUOTE]本文的第 3 部分說明 Enterprise JavaBeans 組件的部署過程,部署并不僅僅是安裝,因為它通常還涉及代碼生成。部署還使用了一個特殊的部署描述符文件,此文件支持控制企業級 bean 行為(如某個 bean 是否需要事務)的參數。bean 部署的這一特性支持 bean 行為的說明性、綱領性規范的 EJB 目標。第 3 部分還比較了持久性的兩種主要類型,bean 管理式持久性和容器管理式持久性,并討論了 EJB 組件與 CORBA 的關系。同時還給出了一個簡單的三層 EJB 應用程序。[/BLOCKQUOTE]
[b]部署過程[/b]
Enterprise JavaBeans (EJB) 組件是在稱為[I]部署[/I]的特定過程中安裝的。由容器組件提供對部署過程的支持。在高級別上,部署由下列步驟組成: [UL][LI]bean 的開發人員創建必需的類文件、接口文件和控制信息。 [LI]容器分析輸入文件并生成必要的類。 [LI]容器將條目添加到指向本地對象的 JNDI 命名空間中。[/LI][/UL]
EJB 組件的開發人員編寫 bean 的 Java 源文件,此文件包含為這個 bean 提供功能的業務邏輯方法,還包括 ejbCreate() 方法。bean 類還必須實現 javax.ejb.SessionBean 接口或 javax.ejb.EntityBean 接口。此外,bean 的開發人員編寫接口文件,定義對 javax.ejb.EJBHome 接口和 javax.ejb.EJBObject 接口的擴展。EJBHome 接口的擴展,稱為 bean 的[I]本地接口[/I],包含一個創建方法,并且如果 bean 是一個實體 bean,它還會包含一個 finder 方法。EJBObject 接口的擴展,稱為 bean 的[I]遠程接口[/I],指定在 bean 本身中定義的業務邏輯方法。
bean 的開發人員提供由部署描述符、環境屬性和清單式文件組成的控制信息。 [UL][LI]部署描述符是 javax.ejb.deployment.SessionDescriptor 對象或 javax.ejb.deployment.EntityDescriptor 對象的序列化實例。 [LI]環境屬性作為鍵-值對存儲在一個文件中,可通過 java.util.Properties 對象訪問此文件。 [LI]清單式文件是標識企業級 bean 及其相關文件所必需的。 [/LI][/UL]企業級 bean 的類文件、這兩個接口的類文件、部署描述符文件、環境屬性文件和清單式文件都是使用名為 ejb-jar 的文件格式歸檔的。所生成的 ejb-jar 文件提供給容器,作為部署過程的輸入。
在部署時,容器分析 ejb-jar 文件的內容,并采取必要的操作使此 bean 可用。這些操作包括:生成實現 bean 的本地和遠程接口的新 Java 類,將本地接口實現綁定到 JNDI 命名空間中,生成樁模塊和 skeleton helper 類,后者是支持 RMI 通信所必需的。容器也可以生成 bean 的子類,并入容器專用的代碼,以方便對 bean 的管理。部署時由容器生成的類通常是容器專用的,而不像 EJB 組件本身那樣具有可移植性。
[b]持久性、事務和安全[/b]
在為 EJB 組件提供持久性、事務和安全服務方面,EJB 容器可扮演主要角色。是將這些服務的職責指定給容器,還是假定職責由 bean 自身負責,EJB 規范為 bean 的開發人員提供了靈活性。例如,對實體 bean 的持久性支持既可以由 bean 管理,也可以由容器管理。如果 EJB 組件開發人員選擇使用容器管理式持久性,他們就會在部署描述符中添加一個稱為 containerManagedFields 的屬性。根據 EJB 規范:
[BLOCKQUOTE]“containerManagedFields 屬性的值是一個實例字段列表,企業級 bean 提供者希望,容器通過從數據庫加載或將其存儲到數據庫,來管理這些實例字段。企業級 bean 代碼不應該包含任何數據庫訪問調用 -- 數據庫訪問調用將由容器工具在部署時生成。[/BLOCKQUOTE]
[BLOCKQUOTE]“專用于提供容器管理式持久性支持的容器,通常將提供豐富的部署時工具,以允許企業級 bean 部署者建立實例字段到基礎數據源的映射。一般認為,盡管容器提供者的工具簡化了映射進程,但映射進程仍可能涉及到 bean 部署者(即映射進程不是全自動的)。”([I]Enterprise JavaBeans Specification 1.0[/I])[/BLOCKQUOTE]
除了支持容器管理式持久性以外,EJB 體系結構還支持容器對事務的管理。該規范規定:
[BLOCKQUOTE]“Enterprise JavaBeans 是一種高級組件框架,它試圖使應用程序開發人員不面對系統的復雜性。因此,大多數企業級 bean 及其客戶機不需要通過程序訪問事務管理。”([I]Enterprise JavaBeans Specification 1.0[/I])[/BLOCKQUOTE]
當 bean 的開發人員依賴容器進行事務管理時,就稱為[I]容器管理式定界[/I],容器使用在部署時提供的事務屬性:
[BLOCKQUOTE]“無論客戶機何時調用企業級 bean,容器都會介入這個方法調用。這種介入允許容器通過事務屬性顯式控制事務定界。例如,如果企業級 bean 部署了 TX_REQUIRED 事務屬性,則無論何時,只要客戶機調用支持事務的企業級 bean,容器就會自動啟動事務,而客戶機并不與任何事務上下文相關聯?!?[I]Enterprise JavaBeans Specification 1.0[/I])[/BLOCKQUOTE]
如果開發人員選擇在 bean 內支持事務,則他們在部署描述符中指定 TX_BEAN_MANAGED 事務屬性,然后就可以在 bean 自身內部自由使用 javax.transaction.UserTransaction 接口劃分事務邊界。通過認出 TX_BEAN_MANAGED 事務屬性,容器就能知道不必介入事務支持。
通過增強 AccessControlEntry 對象和 RunAs 安全標識中指定的限制,容器為 EJB 組件提供安全支持。AccessControlEntry 對象在 bean 級別上或針對單個方法,將 Identity 對象與企業級 bean 相關聯。Identity 對象反映允許調用 bean 的方法的用戶或角色。當容器試圖訪問數據源或另一個 bean 時,它們也會將 RunAs 安全身份應用于 EJB 組件??蓪?RunAs 身份設置為等同于某個特定用戶帳戶、有權限的系統帳戶或客戶機安全身份。訪問控制和 RunAs 的信息是 bean 的開發人員在部署描述符中指定的,將影響容器管理 bean 的與安全有關的行為方式。
雖然 EJB 1.0 規范也提到安全問題,但更詳細的安全功能定義,見該規范的后續版本。
[b]CORBA 和 EJB 技術的關系[/b]
公用對象請求代理程序體系結構 (CORBA) 為分布式對象的平臺中立和語言中立的計算環境奠定了基礎。在 CORBA 環境中,功能駐留于對象之中,而客戶機可通過對象請求代理程序 (ORB) 訪問這些對象。完整的 CORBA 實現提供 ORB,外加稱為 CORBA 對象服務和 CORBA 公用工具的幾個運行時服務。也可只提供 ORB,不提供相關聯的對象服務和公用工具(例如,IBM 就提供這樣的兩種獨立 ORB)。實現基本 ORB 功能的軟件稱為 [I]ORB 核心[/I]。為了支持語言無關性,CORBA 應用程序是用接口定義語言 (IDL) 編寫的。該語言在語法上類似于 C++,但不包含語義:IDL 中指定的操作是操作接口,而不是操作實現。由于它對多種平臺和多種語言的支持,以及源自其分布式特征的可伸縮性,CORBA 非常適合于管理企業規模的信息系統。
設計 EJB 規范也是為了支持企業信息系統。這樣說來,CORBA 是一個競爭者嗎?根據 [I]Frequently Asked Questions for Enterprise JavaBeans[/I],答案是否定的:
[BLOCKQUOTE]“實際上,EJB 技術很好地補充了 CORBA。CORBA 提供了一個強大的基于標準的基礎結構,可在此結構之上構建 EJB 服務器。EJB 技術使得在 CORBA 基礎結構的頂層構建應用程序變得更為容易?!保╗I]Enterprise JavaBeans 常見問題解答[/I])[/BLOCKQUOTE]
雖然 EJB 規范和 CORBA 規范說明的是不同的技術,但 EJB 實現目前利用 CORBA 技術的某些方面。一個例子就是 RMI/IIOP。EJB 規范要求 EJB 組件及其容器使用 Remote Method Invocation (RMI) 技術,實現分布式對象之間的方法調用。 RMI 規定遠程方法的語法和語義,但并不規定應使用何種傳輸協議提供網絡連接。CORBA Internet 對象請求代理程序間協議 (IIOP) 基本上定義了通過 TCP/IP 傳輸 CORBA 消息的一種方法。開發使用 IIOP 消息形式交換 RMI 數據的 EJB 實現,說明了 EJB 應用程序怎樣才能有效地使用 CORBA 技術的各部分。這種網絡也支持與 CORBA 應用程序的互操作性,后者使用 IIOP 發送本地 CORBA 消息,與 RMI 無關。IBM 的 EJB 實現,即 WebSphere Application Server,優化了 IIOP 的使用,方法是,弄清楚分布式對象何時駐留在同一臺服務器上,并且只在對象確實在遠程時才調用 IIOP。
為了方便既并入 EJB 技術,又并入 CORBA 技術的企業系統的開發,Sun Microsystems 在 EJB 規范和 CORBA 之間創建了一種映射。將 EJB 體系結構映射到 CORBA,影響到 EJB 技術的幾個方面,包括對象分布、命名和事務。CORBA 映射的主要目的是,保證不同廠商構建的 EJB 服務器之間的互操作性?;ゲ僮餍蕴峁┮韵潞锰帲?[UL][LI]CORBA 客戶機可以訪問部署在基于 CORBA 的 EJB 服務器上的 EJB 組件 [LI]客戶機程序在事務中可以將對 CORBA 對象的調用,與對企業級 bean 的調用混合在一起 [LI]事務可以跨多個 bean,而這些 bean 又位于來自不同廠商的基于 CORBA 的多臺 EJB 服務器上 [LI]使用來自某個廠商的 ORB 的客戶機,可以訪問另一個廠商基于 CORBA 的 EJB 服務器上的 bean [/LI][/UL]
對于要訪問 EJB 組件的 CORBA 客戶機來說,bean 接口被映射到 IDL。例如,可將股票交易 bean 中定義的 buy() 和 sell() 方法,指定為 IDL 文件中的 CORBA 操作。非 bean 的 CORBA 客戶機,如 C++ 客戶機,可以訪問這個 bean,并用標準 CORBA 調用來調用 bean 的方法。如果容器使用 IIOP 作為它的分布式對象協議,則該容器的職責是,生成與企業級 bean 及其接口對應的 IDL。
EJB 命名服務,它以“CORBA 對象服務”命名服務為基礎,使 EJB 組件可用于 CORBA 客戶機。Java Naming and Directory Interface (JNDI) 可提供到 CORBA 命名服務的接口,同時,客戶機既可以通過 JNDI 調用間接訪問基礎命名服務,也可以通過“CORBA 對象服務” (COS) 命名 API 直接訪問該服務。
EJB 事務支持依賴于 CORBA Transaction Service,即 Object Transaction Service (OTS)。Java Transaction Service (JTS) 代表 OTS 的 Java 綁定,它是語言中立的?;?CORBA 的 EJB 容器必須識別 CORBA 客戶機通過 OTS 接口發出的事務邊界,以及 EJB 應用程序通過 Java Transaction API (JTA) 接口發出的事務,JTA 是到 JTS 的應用程序級接口。JTA 還代表 Open Group XA 接口的 Java 綁定,以便將應用程序資源連接到外部事務管理器。JIA 中含存的 javax.transaction.UserTransaction 接口,為事務邊界的應用程序級控制提供 API。UserTransaction 接口,既可由其事務屬性設置為 TX_BEAN_MANAGED 的 bean 使用,以可由 Java 客戶機使用。[/TD][/TR][/TABLE]
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -