国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

什么是 Enterprise JavaBeans 組件?(一)

2019-11-18 14:47:13
字體:
供稿:網(wǎng)友

  出自:ibm KenNordby
第一部分:EJB 體系結(jié)構(gòu)的歷史和目標(biāo)

本文概述 EnterPRise javaBeans (EJB) 技術(shù),旨在讓讀者快速理解基本概念。第 1 部分講述 EJB 技術(shù)的歷史和某些目標(biāo)、優(yōu)點和技術(shù)。為了簡潔明了,有選擇地講述 EJB 技術(shù)的一些要害要素。請注重,雖然 EJB 組件依靠于一些基礎(chǔ)的 Java 服務(wù)(如 Java Transaction Service),但使用 EJB 組件及熟悉這些組件的好處并不需要把握這些相關(guān)技術(shù)的知識。

Enterprise JavaBeans 技術(shù)自 1998 年 3 月問世以來很受好評。下面這段話就是一個例子:

“自從兩年多以前問世以來,Enterprise JavaBeanstm 技術(shù)在平臺供給商和企業(yè)的開發(fā)小組中,同樣都保持著空前的發(fā)展勢頭。這是因為 EJBTm 的服務(wù)器端組件模型簡化了中間件組件的開發(fā),這些中間組件都是事務(wù)性的、可伸縮的和可移植的。Enterprise JavaBeans 服務(wù)器通過為中間件服務(wù)(如事務(wù)處理、安全性、數(shù)據(jù)庫連接及其他)提供自動支持,降低了開發(fā)中間件的復(fù)雜程度。”(Sun Microsystems 網(wǎng)站)

Enterprise JavaBeans 這一名稱利用了 Java bean ? 這種可移植、可重用的 Java 軟件組件的聲望。Enterprise JavaBeans 技術(shù)把 Java 組件的概念從客戶機(jī)域擴(kuò)展到了服務(wù)器域:這是 Java 技術(shù)成長過程中有重大意義的一步,它使 Java 技術(shù)發(fā)展成為一種強(qiáng)健的、可伸縮的環(huán)境,能夠支持以任務(wù)為要害的企業(yè)信息系統(tǒng)。

服務(wù)器上的 Java 應(yīng)用程序
Java 編程語言最初在 Web 開發(fā)人員中獲得好評的一個原因是,它支持稱為 applet 的可下載 Java 程序。對 Applet 的支持以 Applet 類的形式內(nèi)置到了 1.0 版的 Java Development Kit (JDK) 中。按照 1.0 版的時間框架,Java 開發(fā)是以 applet 和應(yīng)用程序作為中心的。基于 JDK 1.0 版的 Java 讀物都是從 applet 和應(yīng)用程序的角度來描述 Java 編程的:

“Java 程序由更多的類定義中的某一個組成,每個類定義均已編譯成它自已的 Java 虛擬機(jī)對象代碼的 .class 文件。這些類之一必須定義一個叫做 main() 的方法,程序就是從這個方法開始運行的。想調(diào)用一個 Java 程序,需要運行 Java 解釋器 java,并指定包含 main() 方法的類的名稱。請注重 Java applet 并不是一個應(yīng)用程序 ? 它是一個由已在運行的 Java 應(yīng)用程序(如 Web 瀏覽器或 applet 查看器)裝入并運行的 Java 類。”(見 Flanagan 所著的 Java in a Nutshell)

Java 應(yīng)用程序可以在服務(wù)器上運行,但是不管是在客戶機(jī)-服務(wù)器環(huán)境下,還是在基于 Web 的環(huán)境下,JDK 中都沒有提供讓 Java 應(yīng)用程序?qū)S糜诜?wù)器機(jī)器的接口或包。熟悉到 Java 在 Web 環(huán)境下作為一種服務(wù)器語言的潛力,Sun Microsystems 編寫了 Java Servlet 規(guī)范。servlet 在許多方面與 applet 相似,它是專門為在 Web 服務(wù)器機(jī)器上運行而設(shè)計的 Java 程序:

“servlet 是由容器治理的 Web 組件,可產(chǎn)生動態(tài)內(nèi)容。servlet 是一種小型的、與平臺無關(guān)的 Java 類,被編譯成體系結(jié)構(gòu)中立的字節(jié)代碼,這種代碼可以動態(tài)地加載到一個 web 服務(wù)器上,并由此 web 服務(wù)器運行。servlet 通過一種由 servlet 容器實現(xiàn)的請求-響應(yīng)模型與 Web 客戶機(jī)進(jìn)行交互。這種請求-響應(yīng)模型建立在超文本傳輸協(xié)議 (HTTP) 行為的基礎(chǔ)之上。”(見 JavaSoft 的“Java Servlet API Specification”)

在一臺 Web 服務(wù)器控制下,在多臺服務(wù)器上運行若干小型用戶程序,這種想法并不新鮮 ? 一段時間以來,公共網(wǎng)關(guān)接口 (CGI) 程序(常被稱為 CGI 腳本)一直起著這種作用,并推動了 Web 的普及。但 Java servlet 可以以更高的效率和可移植性來實現(xiàn)這一目的,因而可望最終會取代 CGI 程序。為 servlet 提供運行時環(huán)境的軟件(通常被稱為 servlet 引擎)可以添加到現(xiàn)有的、本身并不支持 Java 可執(zhí)行程序的 Web 服務(wù)器上。

Java servlet 的出現(xiàn),為應(yīng)用程序員使用 Java 來創(chuàng)建 Web 應(yīng)用程序開辟了新的途徑。但是,僅有 servlet 還不能為真正的企業(yè)計算提供完整的模型。CGI 應(yīng)用程序本身往往不是完整的應(yīng)用程序,在處理接收自 Web 瀏覽器上用戶的信息請求時,CGI 只是整個處理過程中的一個中間步驟。例如,CGI 應(yīng)用程序的一種常見用途是訪問數(shù)據(jù)庫。將它用于這種任務(wù)時,CGI 程序提供一種方法,將用戶的數(shù)據(jù)請求連接到能滿足這種請求的企業(yè)數(shù)據(jù)庫。CGI 程序經(jīng)常充當(dāng)一種中間軟件,從 Web 瀏覽器接收請求,決定必須調(diào)用哪些計算資源來滿足這些請求,并向瀏覽器發(fā)回響應(yīng)。Java servlet 與 CGI 程序一樣,最適合充當(dāng)連接前端 Web 請求與后端數(shù)據(jù)資源的中間層組件。

三層體系結(jié)構(gòu)
Web 編程向服務(wù)器端 Java 應(yīng)用程序的演化,也帶來了體系結(jié)構(gòu)的演化,使它脫離了常規(guī)的客戶機(jī)-服務(wù)器兩層模型,而向一種三層方法發(fā)展。兩層模型當(dāng)時曾經(jīng)具有創(chuàng)新意義,因為它將一些計算任務(wù)從主處理器上卸載到靈巧的客戶機(jī)。常規(guī)的基于 LAN 的數(shù)據(jù)庫應(yīng)用程序就是一個例子,其中數(shù)據(jù)庫治理器服務(wù)器軟件駐留在一個專用的服務(wù)器機(jī)器上,而用戶則通過他們的工作站上的客戶機(jī)代碼來訪問數(shù)據(jù)庫。隨著客戶機(jī)-服務(wù)器模型成長到能付諸使用,就出現(xiàn)了對服務(wù)器可伸縮性和對客戶機(jī)代碼大小和復(fù)雜性的關(guān)注。于是提出了一種三層的體系結(jié)構(gòu),以避免在兩層模型中已察覺到的弱點,使 Web 能成為一個計算平臺:

“許多人...斷言,傳統(tǒng)的客戶機(jī)/服務(wù)器兩層體系結(jié)構(gòu)不會有好的可伸縮性,因為用戶連接和數(shù)據(jù)訪問的數(shù)量無法猜測,而且在一些系統(tǒng)治理上也存在問題。為處理兩層體系結(jié)構(gòu)的限制,許多開發(fā)集體都在轉(zhuǎn)向三層體系結(jié)構(gòu)。這種體系結(jié)構(gòu)大致可以定義為:客戶機(jī)層上的表示層、中間的服務(wù)器和后端的某種數(shù)據(jù)庫。這種設(shè)想的目的就是緩和客戶機(jī)或數(shù)據(jù)庫服務(wù)器上的代碼膨脹,集中治理業(yè)務(wù)邏輯,更靈活地使用數(shù)據(jù)庫,而不僅是使用所存儲的過程和觸發(fā)器。”(見 Kim 的“Looking for a 3-Tier App Builder?”)

一個三層結(jié)構(gòu)模型通常被想像成有一個 Web 瀏覽器作為客戶層。Web 瀏覽器由于有可能成為一種真正的通用客戶機(jī),使它從觀念上取代了兩層結(jié)構(gòu)的“胖客戶機(jī)”。假如瀏覽器作為 Web 應(yīng)用程序體系結(jié)構(gòu)的標(biāo)準(zhǔn)瘦客戶機(jī)獲得認(rèn)可,那么以前駐留在兩層模型的胖客戶機(jī)中的功能會怎么樣呢?現(xiàn)在,應(yīng)用程序?qū)S玫墓δ懿⒉灰浦不胤?wù)器(例如數(shù)據(jù)庫治理器),而是有意將它駐留在一個新的中間層上。中間層支持應(yīng)用程序服務(wù)器軟件,這種軟件是中間件的一種形式,它處于第一層上瘦客戶機(jī)的最小功能和第三層上服務(wù)器端業(yè)務(wù)系統(tǒng)的豐富功能之間。由于三層體系結(jié)構(gòu)與 Web 處理模型有密切關(guān)系,所以中間層應(yīng)用程序服務(wù)器常被視為 Web 服務(wù)器的一種功能擴(kuò)展。現(xiàn)有的 Web 應(yīng)用程序利用 CGI 程序,將來自 Web 瀏覽器的用戶請求傳送到不基于 Web 的業(yè)務(wù)系統(tǒng),并向瀏覽器返回響應(yīng),就是三層模型的一種實現(xiàn)。這些應(yīng)用程序逐漸向 servlet 技術(shù)的轉(zhuǎn)移說明三層模型正在增強(qiáng)。

JavaBeans 組件
JavaBeans 規(guī)范將“組件軟件”的概念引入到 Java 編程的領(lǐng)域。組件是自含的、可重用的軟件單元;而 JavaBeans 組件,則可以使用可視的應(yīng)用程序開發(fā)工具,可視地將它們編寫到 Java 程序中。JavaBeans 規(guī)范為 Java 開發(fā)人員提供了一種“組件化”其 Java 類的方法:

Bean 是一些 Java 類,可在一個可視的構(gòu)建器工具中操作它們,并且可以將它們一起編寫到應(yīng)用程序中。任何具有某種特性和事件接口約定的 Java 類都可以是一個 Bean。(見 JavaSoft,“Using the Beans Development Kit 1.0”)

假如軟件重用是一個好主意,那么是否應(yīng)該讓每一個 Java 類都成為 Java bean 呢?假如 Java 類滿足某些準(zhǔn)則,它們就適于充當(dāng) bean 的角色:

在開發(fā)任何新軟件之前,都值得考慮是否用 JavaBean 的形式來開發(fā)它。假如軟件模塊要既能夠可視地操作,又能夠定制以達(dá)到某些效果,則這種軟件模塊就可能適于做成一個 JavaBean。為幫助您確定要開發(fā)的軟件是否應(yīng)該是一個 JavaBean,假定它應(yīng)該是用 Java 編寫的,請向您自已提出以下問題,并相應(yīng)地作出決定:

是否打算讓它可重用?或者,它會是可重用的嗎?
是否希望將它與其他可重用的 Java 組件一起使用?
是否預(yù)計會在 IDE 工具中使用它?

假如上述問題的答案都是肯定的,則它應(yīng)該作為 JavaBean 來開發(fā)。(見 developerWorks 的“JavaBeans Guidelines”)

JavaBean 概念是為了在 Java 編程環(huán)境中支持可重用的組件,它是一種一般性的設(shè)計方法,適用于客戶機(jī)或服務(wù)器機(jī)器上運行的 Java 程序。由于對可視的構(gòu)建器工具的強(qiáng)調(diào),也由于許多 Java bean 都是圖形用戶界面 (GUI) 組件,所以 JavaBean 組件可能被視為一種客戶端技術(shù)。但是,并不要求 Java bean 都是可視的,并且它們也可以用于服務(wù)器環(huán)境中。

編碼為 Java bean 的 Java 類通常具有以下特征:

使用設(shè)計模式。這些模式就是方法和接口的編碼約定。
支持可視的軟件開發(fā)工具。類必須將變量(稱為屬性)、方法和事件展示出來。
可以定制。定制包括能支持缺省的屬性編輯器,或者提供單一的定制規(guī)則。定制使開發(fā)人員得以在不更改源代碼的情況下更改 bean 的行為。
支持自省 (introspection)。這指的是將屬性、方法和事件公開給其他類,可以通過設(shè)計模式或通過創(chuàng)建 BeanInfo 類來完成這種自省。
是持久的。這就答應(yīng)在一個可視構(gòu)建器中定制一個 bean,然后以其定制后的狀態(tài)加以保存。
Java 2 Platform, Enterprise Edition
Sun Microsystems 發(fā)起了一項稱為 Java 2 Platform, Enterprise Edition (J2EE) 的技術(shù)創(chuàng)新,旨在將 Java 平臺的范圍擴(kuò)展到大規(guī)模服務(wù)器環(huán)境:

“1997 年 4 月 12 日,Sun 公布了一項為企業(yè)環(huán)境開發(fā) Java 平臺的創(chuàng)新成果。使用開放式的 Java Community Process,Sun 促進(jìn)了一組標(biāo)準(zhǔn)的 Java 擴(kuò)展的開發(fā),稱為 Enterprise Java API。這些應(yīng)用程序編程接口 (API) 為各種各樣的中間件的實現(xiàn)提供了不依靠供給商的編程接口。Enterprise Java API 的要點是 Enterprise JavaBeans API,后者為 Java 應(yīng)用程序服務(wù)器定義了一個服務(wù)器端組件模型,以及一個不依靠供給商的編程接口。”(見 Thomas 的“Java 2 Platform, Enterprise Edition: Ensuring Consistency, Portability, and InterOperability”)

J2EE 為 Enterprise JavaBeans 技術(shù)提供了工作環(huán)境。事實上,Sun 把若干項軟件技術(shù)都設(shè)想為這樣的構(gòu)件塊,它們將使大型企業(yè)能夠把以任務(wù)為要害的業(yè)務(wù)系統(tǒng)移植到 Java 環(huán)境中,而 Enterprise JavaBeans 技術(shù)不過是這些技術(shù)之一。EJB 組件是按它們自己的規(guī)范定義的,但 EJB 技術(shù)并不是一項獨立的技術(shù)。它建立在其他 Java 技術(shù)之上,這些技術(shù)由 Sun 和其他 IT 公司聯(lián)合規(guī)定,它們一起提供了這個框架的內(nèi)容,該框架就稱為 Java 2 Platform, Enterprise Edition。

J2EE 中包括以下技術(shù):

Enterprise JavaBeans (EJB) 技術(shù)
Java Interface Definition Language (IDL)
Java Message Service (JMS) API
Java Naming and Directory Interface (JNDI)
Java Remote Method Invocation (RMI) 和 Object Serialization
Java Servlet API
Java Transaction API (JTA)
Java Transaction Service (JTS)
JavaServer Pages (jsp) 技術(shù)
JDBC 數(shù)據(jù)庫訪問 API
參與到這個企業(yè) Java 框架中,并不意味著每項技術(shù)都依靠于所有其他技術(shù)。單獨的規(guī)范文檔指出每項技術(shù)的相關(guān)性。例如,Enterprise JavaBeans 規(guī)范 1.0 發(fā)行版就指明了在定位各個組件時與 JNDI 的相關(guān)性,以及在編程中啟動和停止事務(wù)處理時與 JTA 的相關(guān)性。

EJB 技術(shù)的設(shè)計目標(biāo)
EJB 規(guī)范的第一版以初稿形式于 1997 年 12 月公布,并于 1998 年 3 月作為 1.0 版發(fā)行。規(guī)范作者為 EJB 體系結(jié)構(gòu)制定了以下目標(biāo):

Enterprise JavaBeans 體系結(jié)構(gòu)將是標(biāo)準(zhǔn)的組件體系結(jié)構(gòu),用于以 Java 編程語言構(gòu)建分布式的面向?qū)ο蟮纳虅?wù)應(yīng)用程序。通過把使用不同供給商提供的工具開發(fā)出來的組件組合在一起,Enterprise JavaBeans 體系結(jié)構(gòu)將有可能構(gòu)建分布式的應(yīng)用程序。

Enterprise JavaBeans 體系結(jié)構(gòu)將使編寫應(yīng)用程序變得輕易:應(yīng)用程序開發(fā)人員將不必了解低層次的事務(wù)和狀態(tài)治理的細(xì)節(jié)、多線程、資源共享和其他復(fù)雜的低級 API。但是,將答應(yīng)專家級的程序員直接訪問低級 API。

Enterprise JavaBeans 應(yīng)用程序?qū)⒆裱?Java 編程語言的“一次編寫,隨處運行”的原則。EJB 組件可以只開發(fā)一次,然后在多個平臺上部署,而不需要重新編譯或修改源代碼。

Enterprise JavaBeans 體系結(jié)構(gòu)將處理企業(yè)應(yīng)用程序生命周期中的開發(fā)、部署和運行等方面。

Enterprise JavaBeans 體系結(jié)構(gòu)將定義一些約定,這些約定使多個供給商提供的工具能夠開發(fā)并部署可在運行時互操作的組件。

Enterprise JavaBeans 體系結(jié)構(gòu)將與現(xiàn)有的服務(wù)器平臺兼容。供給商將能夠擴(kuò)展它們的現(xiàn)有產(chǎn)品,以支持 Enterprise JavaBeans 組件。

Enterprise JavaBeans 體系結(jié)構(gòu)將與 Java 編程語言編寫的其他 API 兼容。

Enterprise JavaBeans 體系結(jié)構(gòu)將提供 EJB 組件和非 Java 編程語言應(yīng)用程序之間的互操作性。

Enterprise JavaBeans 體系結(jié)構(gòu)將與 CORBA 兼容。
使用 EJB 技術(shù)的好處
這些設(shè)計目標(biāo)會使企業(yè)和開發(fā)人員得到什么好處呢?下面列出了可望從采用 Enterprise JavaBeans 環(huán)境獲得的好處:

EJB 組件使編寫應(yīng)用程序更為簡單。盡管 EJB 體系結(jié)構(gòu)復(fù)雜,但應(yīng)用程序開發(fā)人員一般都不必再編寫用于訪問系統(tǒng)服務(wù)的代碼。一種稱為 EJB 容器的系統(tǒng)組件使系統(tǒng)服務(wù)可用于 EJB 組件的任務(wù)。

服務(wù)器端商務(wù)邏輯可以移植。除了 Java 語言固有的可移植性外,EJB 體系結(jié)構(gòu)還在 bean 和支持該 bean 的容器之間提供了一套標(biāo)準(zhǔn)化的應(yīng)用程序編程接口。這使開發(fā)人員能夠?qū)?bean 從一種操作環(huán)境移植到另一種操作環(huán)境,而無須重新編寫其源代碼。

可以從現(xiàn)有的軟件組件裝配出服務(wù)器端應(yīng)用程序,這與從現(xiàn)有的 Java bean 可以裝配出客戶端應(yīng)用程序一樣,從而使軟件能夠重用。

EJB 體系結(jié)構(gòu)內(nèi)置了對典型企業(yè)級系統(tǒng)服務(wù)的支持,包括分布式對象、事務(wù)處理、數(shù)據(jù)庫、安全和全局命名。

多家 IT 供給商都采納 EJB 體系結(jié)構(gòu),這是由于有這樣的承諾:客戶將能夠從選定的供給商那里選購軟件組件,如 EJB 組件、容器及 EJB 服務(wù)器;也由于承諾了不同供給商的產(chǎn)品,只要符合 EJB 體系結(jié)構(gòu),就都是可互操作的。

用 EJB 組件構(gòu)建的應(yīng)用程序可以從一個服務(wù)器移植到另一個服務(wù)器,從而支持可伸縮性,這是因為在 EJB 模型中,各個軟件組件都是嚴(yán)格分離的。

EJB 體系結(jié)構(gòu)能保障原有的 IT 投資,這是通過答應(yīng)將現(xiàn)有的信息系統(tǒng)和資產(chǎn)“包裹”在這些應(yīng)用程序中,而不要求客戶更換現(xiàn)有技術(shù)。事實上,在關(guān)系數(shù)據(jù)庫中存儲數(shù)據(jù)的企業(yè)已經(jīng)有了一套已有雛形的實體 bean,正等著通過 EJB 外殼去訪問。

進(jìn)一步考察 JNDI
Enterprise JavaBeans 組件使用 Java Naming and Directory Interface (JNDI) 來訪問各種目錄服務(wù)。JNDI 分兩部分:應(yīng)用程序編程接口 (API) 和服務(wù)供給商接口 (SPI):

“JNDI 體系結(jié)構(gòu)由 JNDI API 和 JNDI SPI 組成。JNDI API 答應(yīng) Java 應(yīng)用程序訪問各種命名和目錄服務(wù)。JNDI SPI 則是設(shè)計來供任意一種服務(wù)的供給商(也包括目錄服務(wù)供給商)使用。這使得各種各樣的目錄服務(wù)和命名服務(wù)能夠透明地插入到使用 JNDI API 的 Java 應(yīng)用程序中。(見 JavaSoft,“JNDI: Java Naming and Directory Interface”)

JNDI API 并不同某種專用的命名技術(shù)或目錄技術(shù)連在一起,也不同任何供給商的目錄服務(wù)連在一起,因此它對 EJB 組件的可移植性有所貢獻(xiàn)。例如,客戶可以從多種不同的技術(shù)中選擇,來為其 EJB 應(yīng)用程序提供目錄服務(wù),這些技術(shù)包括:

LDAP:Sun 的 LDAP 服務(wù)供給商支持 LDAP 協(xié)議的第 2 版和第 3 版。
NIS:Sun 提供一個 NIS 服務(wù)供給商(NIS 即網(wǎng)絡(luò)信息服務(wù),以前稱為黃頁)。
COS 命名:Sun 的 COS 命名服務(wù)供給商提供對 CORBA 命名服務(wù)的訪問。
文件系統(tǒng):Sun 提供一個服務(wù)供給商來訪問文件系統(tǒng)。
RMI 注冊:Sun 為 RMI 注冊提供一個服務(wù)供給商。
Novell:有幾個服務(wù)供給商可提供對目錄服務(wù) NDS 的訪問以及 NetWare 3X 連接庫、Novell 文件系統(tǒng)和其他 Novell 服務(wù)(如擴(kuò)展 NCP)的訪問。
雖然 JNDI 規(guī)范對供給商是中立的,但不應(yīng)認(rèn)為,實現(xiàn) JNDI 接口的應(yīng)用程序服務(wù)器一定要能訪問來自多個供給商的服務(wù)供給商代碼。

JNDI 命名體系結(jié)構(gòu)的要害概念包括:

對象和名稱之間的綁定。
若干稱為命名上下文的綁定集。
命名系統(tǒng),即若干組命名上下文。
命名空間,指一個命名系統(tǒng)中的所有名稱。
名稱分類為原子名稱、復(fù)合名稱和合成名稱。原子名稱是不可分割的,可以綁定到一個對象上。復(fù)合名稱是原子名稱的組合,而合成名稱則跨越多個命名系統(tǒng)。

命名上下文非凡重要:所有的命名操作均是在上下文對象上進(jìn)行的,并且名稱解析過程總是從最初的命名上下文開始。

EJB 應(yīng)用程序是如何使用 JNDI 的呢?JNDI 的主要用途是檢索對 EJB 組件的引用。因為 EJB 框架是一個分布式對象框架,所以 EJB 應(yīng)用程序不應(yīng)當(dāng)假定 EJB 組件的位置。JNDI 就是獲取對 bean 的起始引用的一種機(jī)制。當(dāng)一個 bean 安裝到一個 enterprise bean 服務(wù)器上時,一個被稱為 EJB 容器的軟件組件就負(fù)責(zé)創(chuàng)建各個名稱-對象綁定,使所需的 Java 類文件能使用這個 bean。應(yīng)用程序使用 JNDI 的查找方法來檢索對象引用,如下例所示:

Context initialContext = new InitialContext( );
CartHome cartHome = javax.rmi.PortableRemoteObject.narrow(
initialContext.lookup("applications/shopping_cart"), CartHome.class);

應(yīng)用程序有責(zé)任知道外部名稱,應(yīng)用程序就是通過這個名稱才得以引用一個 enterprise bean,并通過 JNDI 來獲取對該 bean 的引用的。

進(jìn)一步考察 JTA
除 JNDI 以外,Enterprise JavaBeans 體系結(jié)構(gòu)還使用 Java Transaction API (JTA)。因為事務(wù)對維護(hù)數(shù)據(jù)完整性和可靠性很重要,所以支持事務(wù)處理是 EJB 體系結(jié)構(gòu)的一個基本部分。假如企業(yè)應(yīng)用程序是分布式的,事務(wù)處理就會更加重要:

“事務(wù)的概念是一個重要的編程范例,其目的在于簡化既要求可靠性又要求可用性的應(yīng)用程序結(jié)構(gòu),非凡是那些需要同時訪問共享數(shù)據(jù)的應(yīng)用程序。事務(wù)的概念最早是用在商務(wù)運作的應(yīng)用程序中,其中它被用于保護(hù)集中式數(shù)據(jù)庫中的數(shù)據(jù)。后來,事務(wù)的概念已擴(kuò)展到分布式計算的更廣泛的環(huán)境中。今天,事務(wù)是構(gòu)建可靠的分布式應(yīng)用程序的要害,這一點已得到廣泛承認(rèn)。”(見對象治理組的“Transaction Service Specification”)

有時將事務(wù)描述為具有下列特征的工作單元:

原子性 ? 假如因故障而中斷,所有結(jié)果均撤銷
一致性 ? 事務(wù)的結(jié)果保留不變的特性
孤立性 ? 中間狀態(tài)對其他事務(wù)是不可見的
持久性 ? 已完成的事務(wù)的結(jié)果是持久的
事務(wù)的終止有兩種方式:提交一個事務(wù)會使其所有的更改永久不變,而回滾 (rolling back) 一個事務(wù)則撤銷其所有的更改。

對象治理組織 (OMG) 為一種面向?qū)ο蟮氖聞?wù)服務(wù),即對象事務(wù)服務(wù) (OTS),創(chuàng)建了一種規(guī)范。OTS 是 EJB 體系結(jié)構(gòu)內(nèi)的事務(wù)服務(wù)的基礎(chǔ)。下列事務(wù)規(guī)范就是為 enterprise bean 所采用的事務(wù)模型而設(shè):

OMG 的對象事務(wù)服務(wù) (OTS)
Sun Microsystems 的 Transaction Service (JTS)
Sun Microsystems 的 Java Transaction API (JTA)
開放組 (X/Open) 的 XA 接口
這種與語言無關(guān)的對象事務(wù)服務(wù),為一個強(qiáng)健的分布式事務(wù)服務(wù)提供了基本概念、定義和功能。

Java Transaction Service 是 OTS 的 Java 映射,在 org.omg.CosTransactions 和 org.omg.CosTSPortability 這兩個包中定義。JTS 對事務(wù)分界和事務(wù)環(huán)境的傳播之類的服務(wù)提供支持。JTS 功能由應(yīng)用程序通過 Java Transaction API 訪問。

Java Transaction API 指定事務(wù)治理器與分布式事務(wù)中涉及的其他系統(tǒng)組件之間的各種高級接口,這些系統(tǒng)組件有應(yīng)用程序、應(yīng)用程序服務(wù)器和資源治理器等。JTA 功能答應(yīng)事務(wù)由應(yīng)用程序本身、由應(yīng)用程序服務(wù)器或由一個外部事務(wù)治理器來治理。JTA 接口包含在 javax.transaction 和 javax.transaction.xa 這兩個包中。

XA 接口定義了資源治理器和分布式事務(wù)環(huán)境中外部事務(wù)治理器之間的約定。外部事務(wù)治理器可以跨多個資源協(xié)調(diào)事務(wù)。XA 的 Java 映射包含在 Java Transaction API 中。

內(nèi)容預(yù)告
“什么是 Enterprise JavaBeans 組件?”的第二部分將討論 EJB 編程模型。

參考資料

要了解更多有關(guān) Java 技術(shù)和 EJB 體系結(jié)構(gòu)的內(nèi)容,請訪問 Sun 的網(wǎng)站。
關(guān)于從 applet 和應(yīng)用程序的角度看 Java 編程,請閱讀 David Flanagan 所著的 Java in a Nutshell。
下載一份 Java Servlet API Specification 的副本。
下載 Java Developer´s Journal第 3 卷第 1 期中 Tom Kim 所寫的“Looking for a 3-Tier App Builder?”(PDF)。
參加 JavaSoft 的“Using the Beans Development Kit 1.0”課程。
從“JavaBeans Guidelines”中可以發(fā)現(xiàn)一些補(bǔ)充的指導(dǎo)原則,它們使您能開發(fā)出性能優(yōu)良的 Bean,這些 Bean 能夠在大多數(shù)環(huán)境中表現(xiàn)良好,包括流行的各種 IDE 和各種瀏覽器。
閱讀 Patricia Seybold Group 的 Anne Thomas 所寫的“Java 2 Platform, Enterprise Edition: Ensuring Consistency, Portability, and Interoperability” 中對 J2EE 的具體說明。
查閱“JNDI: Java Naming and Directory Interface” 中的 JNDI 體系結(jié)構(gòu)和接口的概述,以及各種情況和示例。
了解Java 2 Platform, Enterprise Edition 中包含的以下 Java 技術(shù):
Java IDL
Java Message Service (JMS) API
Java Naming and Directory Interface (JNDI)
Java Remote Method Invocation (RMI)
Java Transaction API (JTA)
Java Transaction Service (JTS)
JavaServer Pages (JSP) 技術(shù)
JDBC 數(shù)據(jù)訪問 API
要了解常見問題、與 LDAP 相關(guān)的 RFC 以及更多信息,請訪問 Mark Wahl 的 LDAP 網(wǎng)站。
要了解如何將 linux 配置為 NIS(YP) 或 NIS+ 客戶機(jī)及如何安裝成 NIS 服務(wù)器,請查閱 Linux NIS(YP)/NYS/NIS+ HOWTO。
下載 Java IDL 的命名服務(wù) COS naming。
具體了解 Java Remote Method Invocation (RMI),包括規(guī)范、示例和常見問題。
了解 Novell 提供的大量的產(chǎn)品和解決方案。
訪問 Object Management Group (OMG) 的網(wǎng)站。
查閱開放組的 XA interface 規(guī)范。


作者簡介
Ken Nordby 是位于 Research Triangle Park,North Carolina 的 IBM 軟件開發(fā)實驗室的軟件工程師。作為 SWG ProdUCt Affinity Services 工作組的成員,Ken 和他的 IBM 同事從事 IBM WebSphere Application Server(Enterprise JavaBeans 的 IBM 實現(xiàn))的開發(fā)及咨詢工作。可以通過 nordby@us.ibm.com 與 Ken 聯(lián)系。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 治多县| 济南市| 望奎县| 新泰市| 苍梧县| 化隆| 邹城市| 太仓市| 扶沟县| 金堂县| 伊金霍洛旗| 休宁县| 宜章县| 青河县| 古浪县| 镇雄县| 武冈市| 哈尔滨市| 元谋县| 界首市| 兖州市| 桂林市| 永济市| 苍山县| 类乌齐县| 扎赉特旗| 辰溪县| 大洼县| 屏南县| 道孚县| 曲靖市| 城口县| 德州市| 淳化县| 滨海县| 绥阳县| 石渠县| 龙门县| 三门县| 福建省| 韶山市|