偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

POJO與Spring和EJB 3.0的對(duì)比

開(kāi)發(fā) 后端
Spring和EJB 3.0的目標(biāo)都是把中間件服務(wù)傳遞給松散耦合的簡(jiǎn)單舊式Java對(duì)象POJO。本文簡(jiǎn)單比較POJO與Spring和EJB 3.0的區(qū)別。

愛(ài)因斯坦曾經(jīng)說(shuō)過(guò):"每件事物都應(yīng)該盡可能簡(jiǎn)單,而不是更簡(jiǎn)單"。的確,對(duì)科學(xué)真理的追求都是為了簡(jiǎn)化理論的根本假設(shè),這樣我們才能處理真正麻煩的問(wèn)題。企業(yè)級(jí)軟件的開(kāi)發(fā)也是這樣的。

簡(jiǎn)化企業(yè)級(jí)軟件開(kāi)發(fā)的關(guān)鍵是提供一個(gè)隱藏了復(fù)雜性(例如事務(wù)、安全性和永續(xù)性)的應(yīng)用框架。良好設(shè)計(jì)的框架組件可以提升代碼的重復(fù)使用(reuse)能力,提高開(kāi)發(fā)效率,從而得到更好的軟件質(zhì)量。但是,目前J2EE 1.4中的EJB 2.1框架組件被人們普遍認(rèn)為是設(shè)計(jì)較差的和過(guò)于復(fù)雜的。Java開(kāi)發(fā)者對(duì)EJB 2.1很不滿(mǎn),他們已經(jīng)試驗(yàn)了多種其它的用于中間件服務(wù)傳送的方法。最引人注目的,下面兩個(gè)框架組件已經(jīng)引起開(kāi)發(fā)者的巨大興趣和積極的反映。它們很可能成為未來(lái)企業(yè)級(jí)Java應(yīng)用程序可供選擇的框架組件。

◆Spring框架組件是一個(gè)流行的,但是非標(biāo)準(zhǔn)的開(kāi)放源代碼框架組件。它主要是由Interface21 Inc.公司開(kāi)發(fā)和控制的。Spring框架組件的架構(gòu)是基于依賴(lài)注入(DI)設(shè)計(jì)模式的。Spring可以單獨(dú)地或者與現(xiàn)有的應(yīng)用程序服務(wù)器一起工作,它大量地使用XML配置文件。

◆EJB 3.0框架組件是一個(gè)標(biāo)準(zhǔn)的框架組件,由Java社區(qū)組織(JCP)定義,并受到所有主流的J2EE廠(chǎng)商支持。預(yù)發(fā)布的EJB 3.0規(guī)范的開(kāi)放源代碼和商業(yè)實(shí)現(xiàn)都可以在JBoss和Oracle上看到了。EJB 3.0大量使用Java注釋?zhuān)╝nnotation)。

這兩個(gè)框架組件的核心設(shè)計(jì)理念是相同的:兩者的目標(biāo)都是把中間件服務(wù)傳遞給松散耦合的簡(jiǎn)單舊式Java對(duì)象(POJO)。這些框架組件通過(guò)在運(yùn)行時(shí)截取執(zhí)行內(nèi)容或向POJO注入服務(wù)對(duì)象,把應(yīng)用程序服務(wù)與POJO捆綁在一起。POJO本身不關(guān)心捆綁的過(guò)程,并且對(duì)框架組件幾乎沒(méi)有依賴(lài)。其結(jié)果是,開(kāi)發(fā)者可以聚焦于業(yè)務(wù)邏輯,個(gè)人可以在沒(méi)有框架組件的情況下測(cè)試他們的POJO。此外,由于POJO不需要從框架組件中繼承或?qū)崿F(xiàn)框架組件接口,開(kāi)發(fā)者建立繼承結(jié)構(gòu)和構(gòu)建應(yīng)用程序的時(shí)候都有高度的靈活性。

但是,盡管兩者的設(shè)計(jì)理念是相同的,它們傳遞POJO服務(wù)時(shí)卻采用了完全不同的方法。盡管目前已經(jīng)出版了大量的圖書(shū)和文章來(lái)把Spring或EJB 3.0與EJB 2.1進(jìn)行對(duì)比,但是它們都沒(méi)有對(duì)Spring與EJB 3.0之間的差異進(jìn)行認(rèn)真的研究。在本文中,我將研究Spring和EJB 3.0框架組件之間的關(guān)鍵差異,并討論它們的優(yōu)缺點(diǎn)。本文的主題也可以應(yīng)用在其它一些名氣稍小的企業(yè)級(jí)中間件框架組件上,因?yàn)樗鼈兌季劢褂?松散耦合的POJO"設(shè)計(jì)。我希望本文能夠幫助你選擇符合需求的最佳的框架組件。
廠(chǎng)商無(wú)關(guān)性(Independence)

開(kāi)發(fā)者選擇某種Java平臺(tái)的一個(gè)最重要的理由就是該平臺(tái)的廠(chǎng)商無(wú)關(guān)性。EJB 3.0是一個(gè)開(kāi)放的、標(biāo)準(zhǔn)的、具有廠(chǎng)商無(wú)關(guān)性的平臺(tái)。EJB 3.0規(guī)范是由企業(yè)級(jí)Java團(tuán)體中所有主流開(kāi)放源代碼和商業(yè)廠(chǎng)商開(kāi)發(fā)和支持的。EJB 3.0框架組件把開(kāi)發(fā)人員與應(yīng)用程序服務(wù)器實(shí)現(xiàn)(implementation)隔離開(kāi)來(lái)了。例如,盡管JBoss的EJB 3.0實(shí)現(xiàn)是基于Hibernate的,而Oracle的EJB 3.0實(shí)現(xiàn)是基于TopLink的,但是開(kāi)發(fā)人員并不需要學(xué)習(xí)Hibernate或TopLink的特殊API,就可以讓他們的應(yīng)用程序在JBoss和Oracle上運(yùn)行。廠(chǎng)商無(wú)關(guān)性把EJB 3.0框架組件與其它的POJO中間件框架組件區(qū)分開(kāi)來(lái)了。

但是,很多EJB 3.0的批評(píng)家迅速指出,在寫(xiě)這篇文章的時(shí)候,EJB 3.0規(guī)范還沒(méi)有達(dá)到最終發(fā)表的版本。在EJB 3.0被所有主流的J2EE廠(chǎng)商采用之前可能還需要一到兩年時(shí)間。但是,即使你的應(yīng)用程序服務(wù)器還沒(méi)有自然地(natively)支持EJB 3.0,你還是可以通過(guò)下載和安裝一個(gè)"嵌入式的" EJB 3.0產(chǎn)品,在服務(wù)器上運(yùn)行EJB 3.0應(yīng)用程序。例如,JBoss嵌入式EJB 3.0產(chǎn)品是開(kāi)放源代碼的,可以在任何與J2SE-5.0兼容的環(huán)境中(例如,在Java應(yīng)用程序服務(wù)器中)運(yùn)行。它現(xiàn)在正在進(jìn)行beta測(cè)試。其它的廠(chǎng)商也可能很快發(fā)布他們的嵌入式EJB 3.0產(chǎn)品,特別是用于規(guī)范的"數(shù)據(jù)永續(xù)性"部分的產(chǎn)品。

另一方面,Spring一直是非標(biāo)準(zhǔn)的技術(shù),而且在可以預(yù)見(jiàn)的未來(lái)它仍然是這樣的。盡管你可以把Spring框架組件與任何應(yīng)用程序服務(wù)器一起使用,但是Spring應(yīng)用程序都被"鎖定"在Spring自身和你所選擇的集成到Spring中的特定服務(wù)中了。

◆盡管Spring框架組件是一個(gè)開(kāi)放源代碼項(xiàng)目,但是它仍然擁有配置文件的專(zhuān)利XML格式和專(zhuān)利編程接口。當(dāng)然,這類(lèi)"鎖定"發(fā)生在任何非標(biāo)準(zhǔn)的產(chǎn)品上,Spring也不例外。但是它卻造成了:你的Spring應(yīng)用程序的長(zhǎng)期生存能力依賴(lài)于Spring項(xiàng)目本身(或Interface21 Inc公司,它雇傭了大多數(shù)Spring核心開(kāi)放人員)。此外,如果你使用任何Spring特定的服務(wù),例如Spring事務(wù)管理器或Spring MVC,你就被"鎖定"在這些API中了。

◆Spring應(yīng)用程序需要知道后臺(tái)的服務(wù)提供者。例如,對(duì)于數(shù)據(jù)持續(xù)(data persistence)服務(wù)來(lái)說(shuō),Spring框架組件為JDBC、Hibernate、iBatis和JDO使用了不同的DAO和模板輔助類(lèi)。因此,如果你希望為Spring應(yīng)用程序更換持續(xù)服務(wù)提供者(例如從JDBC切換到Hibernate),你就必須重構(gòu)自己的應(yīng)用程序代碼,使用新的輔助類(lèi)。

服務(wù)集成

從較高的層次看,Spring框架組件位于應(yīng)用程序服務(wù)器和服務(wù)類(lèi)庫(kù)之上。其服務(wù)集成代碼(例如數(shù)據(jù)訪(fǎng)問(wèn)模板和輔助類(lèi))位于框架組件之中,并暴露給應(yīng)用程序開(kāi)發(fā)者。與此不同的是,EJB 3.0框架組件被緊密地集成到應(yīng)用程序服務(wù)器中,服務(wù)集成代碼被封裝在標(biāo)準(zhǔn)的接口中。

其結(jié)果是,EJB 3.0廠(chǎng)商可以積極地優(yōu)化總體性能和開(kāi)發(fā)者體驗(yàn)。例如,在JBoss的 EJB 3.0實(shí)現(xiàn)中,使用EntityManager保持實(shí)體Bean POJO的時(shí)候,下層Hibernate對(duì)話(huà)事務(wù)會(huì)自動(dòng)地與該調(diào)用方法的JTA事務(wù)聯(lián)系在一起,當(dāng)JTA事務(wù)提交的時(shí)候,它也會(huì)提交。如果使用簡(jiǎn)單的@PersistenceContext注釋?zhuān)ū疚暮竺嬗幸粋€(gè)例子),你甚至于可以在有狀態(tài)的(stateful)對(duì)話(huà)bean中把EntityManager和它的下層Hibernate事務(wù)捆綁到一個(gè)應(yīng)用程序事務(wù)上。該應(yīng)用程序事務(wù)在一個(gè)對(duì)話(huà)中跨越了多個(gè)線(xiàn)程,它在事務(wù)性的Web應(yīng)用程序(例如多頁(yè)面購(gòu)物車(chē))中是非常有效的。由于在JBoss中,EJB 3.0框架組件、Hibernate和Tomcat緊密集成,上述的簡(jiǎn)單和集成的編程接口才得以實(shí)現(xiàn)。Oracle的EJB 3.0框架組件和其下層Toplink持續(xù)服務(wù)之間的也實(shí)現(xiàn)了類(lèi)似層次的集成。

EJB 3.0中集成服務(wù)的另一個(gè)例子是群集(clustering)支持。如果你在服務(wù)器群集中部署EJB 3.0應(yīng)用程序,那么所有的失效接續(xù)(fail-over)、負(fù)載均衡、分布式緩存和狀態(tài)復(fù)制服務(wù)都是可以自動(dòng)地供應(yīng)用程序使用的。下層群集服務(wù)都隱藏在EJB 3.0編程接口后面,它們對(duì)于EJB 3.0開(kāi)發(fā)人員來(lái)說(shuō)是完全透明的。

在Spring中,優(yōu)化框架組件與服務(wù)之間的交互操作要困難得多。例如,為了使用Spring的宣告式事務(wù)服務(wù)來(lái)管理Hibernate事務(wù),你必須在XML配置文件中顯式地配置Spring TransactionManager和Hibernate SessionFactory對(duì)象。Spring應(yīng)用程序開(kāi)發(fā)者必須顯式地管理跨多個(gè)HTTP請(qǐng)求的事務(wù)。此外,要在Spring應(yīng)用程序中使用群集服務(wù)也沒(méi)有簡(jiǎn)單的途徑。

服務(wù)集成的靈活性

由于Spring中的服務(wù)集成代碼是作為編程接口的一部分暴露的,應(yīng)用程序開(kāi)發(fā)者可以根據(jù)需要靈活地集成服務(wù)。這個(gè)特性允許你集成自己的"輕量級(jí)"應(yīng)用程序服務(wù)器。Spring最普遍的使用方式是把Tomcat和Hibernate"粘合"在一起來(lái)提供簡(jiǎn)單的數(shù)據(jù)庫(kù)驅(qū)動(dòng)web應(yīng)用程序。在這種情況下,Spring自身提供事務(wù)服務(wù),Hibernate提供持續(xù)(persistence)服務(wù)--這種組織方式在Spring中建立了一個(gè)微型應(yīng)用程序服務(wù)器。

EJB 3.0應(yīng)用程序服務(wù)器沒(méi)有賦予你挑選服務(wù)的靈活性。在大多數(shù)情況中,你得到一組事先包裝好的特性,而你只需要其中的一部分。但是,如果應(yīng)用程序服務(wù)器由模式化的內(nèi)部設(shè)計(jì)主導(dǎo)(類(lèi)似JBoss),那么你就可能把它分開(kāi),去掉一些不必要的特性。在任何情況下,定制成熟的應(yīng)用程序服務(wù)器都不是一個(gè)簡(jiǎn)單的事情。

當(dāng)然,如果應(yīng)用程序的范圍超越了單節(jié)點(diǎn),那么你可能需要捆綁來(lái)自普通應(yīng)用程序服務(wù)器的服務(wù)(例如資源緩沖池、消息隊(duì)列和群集)。在總體的資源消耗方面,Spring解決方案與任何EJB 3.0解決方案一樣,都是"重量級(jí)"的。

在Spring中,靈活的服務(wù)集成使得我們更容易把仿制(mock)對(duì)象(而不是實(shí)際的服務(wù)對(duì)象)捆綁到應(yīng)用程序,用于在容器外部進(jìn)行單元測(cè)試。在EJB 3.0應(yīng)用程序中,大多數(shù)組件都是簡(jiǎn)單的POJO,我們可以很容易地在容器外部測(cè)試這些它們。但是對(duì)于測(cè)試那些涉及到容器服務(wù)的對(duì)象(例如持續(xù)EntityManager),我們推薦在容器內(nèi)測(cè)試,因?yàn)楸绕鸱轮茖?duì)象的方法,它們更簡(jiǎn)單、更牢固、更精確。 XML與注釋的比較
從應(yīng)用程序開(kāi)發(fā)者的角度來(lái)看,Spring的編程接口主要是基于XML配置文件的,而EJB 3.0廣泛使用了Java注釋。XML文件可以表達(dá)復(fù)雜的關(guān)系,但是它們同時(shí)也很冗長(zhǎng)、牢固程度也較低。注釋簡(jiǎn)單明了,但是在注釋中我們卻很難表達(dá)復(fù)雜的或?qū)哟蔚慕Y(jié)構(gòu)。

Spring和EJB 3.0關(guān)于XML或注釋的選擇是依賴(lài)于這兩個(gè)框架組件后面的架構(gòu)的:由于注釋只能保存相當(dāng)少的配置信息,只有預(yù)先集成的框架組件(類(lèi)似在框架組件中已經(jīng)完成了大多數(shù)預(yù)備工作)可以廣泛地把注釋作為配置選項(xiàng)。我們已經(jīng)討論過(guò)了,EJB 3.0符合這種需求,而Spring作為一個(gè)通用的DI框架組件,不符合這個(gè)需求。

當(dāng)然,EJB 3.0和Spring都在學(xué)習(xí)對(duì)方的最佳特性,它們都在某個(gè)程度上支持XML和注釋。例如,在EJB 3.0中XML配置文件是一個(gè)可選的重載機(jī)制,可以用于改變注釋的默認(rèn)行為。注釋也可以用于配置某些Spring服務(wù)。

認(rèn)識(shí)XML和注釋之間的區(qū)別的最好途徑是通過(guò)示例。在下一部分,我們會(huì)看到Spring和EJB 3.0是如何為應(yīng)用程序提供關(guān)鍵服務(wù)的。

 

【編輯推薦】

  1. JavaBeans、EJB和POJO詳解
  2. 擁抱更簡(jiǎn)單的POJO編程模型
  3. 什么時(shí)候在EJB系統(tǒng)中使用XML
  4. EJB3.0的入門(mén)和使用EJB3.0的方法
  5. Spring事務(wù)配置的五種方式
責(zé)任編輯:佚名 來(lái)源: 天極網(wǎng)
相關(guān)推薦

2009-06-12 09:41:07

EJB3.0Spring

2009-06-22 16:19:45

JavaBeansEJBPOJO

2009-06-12 12:46:59

EJB3.0

2009-06-12 09:30:56

EJB3.0Spring+Hibe

2009-06-26 14:37:10

EJB和Spring

2010-06-21 10:35:30

LinuxDeepin

2009-09-24 12:05:35

2009-06-15 16:06:25

JBoss IDE

2009-06-26 14:54:18

Spring支持EJB

2009-06-04 17:33:08

EJB 3.1EJB 3.0

2009-10-29 09:52:55

OSGi

2009-06-11 15:26:05

EJB組件EJB容器

2009-06-12 11:46:39

JavaBeanEJB

2009-02-16 09:25:43

EJBJavaBeanWebSphere

2009-09-08 11:26:35

Spring 3.0

2009-06-11 16:01:17

EJB容器

2009-09-29 09:39:38

Spring 3.0

2010-09-01 16:36:20

DHCPNAT

2025-02-17 09:32:18

2009-07-03 17:39:20

JSP與EJB
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)