Posted on 2005-11-24 11:14
Terry的Blog 閱讀(574)
評論(0) 編輯 收藏 所屬分類:
java語言 、
轉載
Hibernate的未來發展之路
最近半年多來,在Java世界,Hibernate是最引人關注的一個話題。從Gavin King加入EJB3.0 EG,負責制訂EJB3.0的持久層規范;到Gavin King非正式退出JDO EG,并且充滿個人情緒的攻擊JDO2.0規范;到《Hibernate in Action》的發行;再到Hibernate3 Alpha的發布;最后再到最近JBoss 3.0 PR的發布(使用Hibernate3實現Entity Bean)。可以說這其中的每一步都引起業界的側目。
Hibernate在不到3年的時間里,從一個不起眼的開源軟件發展到今天令業界矚目的主流O/R Mapping框架,Gavin King從一個開源軟件的作者成為業界舉足輕重的人物,這多少有些傳奇的色彩。畢竟,單純從技術成就而言,Hibernate不算是最有成就的Java開源框架軟件,到目前為止也不是一個完美無缺的軟件;從個人技術水平而言,Gavin King也不算絕頂高手。
在當前的Java持久層框架中,最流行的O/R Mapping產品分別是Hibernate,JDO和TopLink。
自從去年Gavin King加入JBoss之后,Hibernate已經由一個民間的開源軟件走上了兼容EJB EntityBean的道路。然而更加令人側目的是,Gavin King在EJB3.0 EG中充當了一個非常重要的角色,只要對比一下EJB3.0的EntityBean和Hibernate3,真相就會大白,雖然API接口不同,但是EntityBean的設計理念完全來自于Hibernate。
雖然EJB3.0的EntityBean在相當程度上來源于Hibernate,但是畢竟是不同的API接口,因此Hibernate和EJB3.0 EntityBean究竟是怎樣的一種關系,是很多人心中的疑問。
今年四月份JBoss的Ben Wang訪華期間,我曾經向Ben請教Hibernate的未來發展,他回答說,Hibernate未來將仍舊以獨立的軟件產品存在和發展,既可以outside EJB container使用;同時Hibernate也將做為JBoss EntityBean Implementation,又可以inside EJB container使用。然而如何既inside,又outside,終究缺乏一個感性的認識。
10月8日JBoss發布的EJB3.0 PR揭開了答案。從Sourceforge的CVS服務器上面checkout出來源代碼看一下,我們可以發現,Gavin King對Hibernate3進行了簡單的封裝,將EJB 3.0 EntityBean API調用轉換為內部Hibernate3自己的API,從而實現EJB3.0 EntityBean的兼容。
EJB3.0不承諾脫離容器調用,如果你想享用EJB3.0,則必須運行在某個EJB Vendor提供的容器內,例如你使用JBoss提供的容器,那么你調用的是EntityBean API,這些調用請求會被轉換為Hibernate API的調用請求。這意味著Hibernate實際上提供了兩套API:一套是Hibernate原生API;另一套是兼容EJB3.0 EntityBean API。對于那些需要分布式調用支持,需要EJB容器的開發人員來說,他們選擇后一套API;對于不需要EJB容器的開發人員來說,他們選擇前一套API。這就是Hibernate既定的發展策略。
今年夏天投票通過的JDO2.0標準從某種程度而言,并不遜色于Hibernate當前的版本,有些功能甚至比Hibernate還要好,例如JDO支持對類屬性的lazy loading,而Hibernate要到3才支持,當前Hibernate僅僅支持類的lazy loading。實際上在去年,就已經有很多用戶不斷提出對類屬性的lazy loading的需求,然而Gavin King當時一直不認為這個需求有添加的必要性。再例如被Gavin King形容為“可憎的”JDOQL,實際上是類SQL查詢語言和對象條件查詢的混合體。從功能上來說,不如HQL強大,但是遠比Hibernate自己的條件查詢強很多。
不知道究竟出于什么原因,Gavin King對JDO似乎一直懷有由衷的厭惡,今年5月,他在Hibernate的blog上面對JDO進行了毫不留情的批判,列舉了JDO的種種缺點來解釋為什么EJB3持久層規范沒有把JDO考慮進去。然而事實上他的批判充滿了對JDO的誤解和偏見,例如Gavin King憎恨JDOQL絲毫沒有什么特別的理由,只因為JDOQL不是一個純粹的查詢語言,而是一個混合體,這多少讓人對Gavin King的風度感到遺憾。在被SolarMetric的Abe White反駁之后,同樣沒有風度的說,“我可沒有時間做這種無謂的爭論,事實上每個人都認為他自己的技術是最好的……我是錯了,JDO那伙人也錯了,每個人都會犯錯誤……”。(所以說人無完人阿!)
JDO2規范的出臺事實上構成了對Hibernate,乃至基于Hibernate理念的EJB3.0 EntityBean的嚴重威脅。JDO1.0規范在功能上的嚴重缺失導致了JDO無力面對Hibernate和TopLink的競爭,然而功能基本完備的JDO2挾眾多JDO Vendor商業支持的合力,同時JDO規范可以避免產品鎖定在某個Vendor的優勢,已經將競爭的天平拉直。
然而JDO2和EJB3兩大商業主流標準的分裂,是大部分人,甚至包括廠商所不希望看到的。 于是最終EJB3的Lead Linda DeMichiel和JDO2的Lead Craig Russell聯名發表公開信,宣布了一個合并EJB3和JDO2持久層規范的計劃,新的持久層規范將以JSR-220(EJB3.0)的持久層規范為基礎,融合JDO2的部分特性。新的持久層規范將進入J2EE1.5之中,獨立于EJB存在,既可以inside J2EE容器來使用,也可以脫離J2EE容器,獨立的運行。
這個新的持久層框架可以說完全是一個政治的產物。EJB Vendors出于自身利益反對JDO,使得JDO沒有辦法成為J2EE的一部分,然而標準的分裂也是大部分人更加不希望看到的,于是最終JDO成了政治斗爭的犧牲品。從表面上來看,JDO和EJB3.0 EntityBean都將被新的持久層框架取代,似乎JDO并沒有吃虧,但實際上JDO2標準已經成熟,部分JDO領導廠商的產品已經蓄始待發,而EJB3.0 EntityBean還處于Early Draft,等待產品誕生至少也是一年之后的事情了;另外值得耐人尋味的是,新的持久層框架將基于當前EJB3.0 EntityBean,再結合JDO2的規范,并且將處于EJB3.0 EG的控制之下,再加入一些JDO2 EG的成員。因此可以看出來新的持久層框架無疑還是以EJB3.0 EG為主導進行制定的。
從長遠來看,EJB3和JDO2的政治斗爭對雙方都有好處,長期分裂帶來的后果對雙方的發展都不利,然而從短期來看,JDO2確實是在這場政治斗爭中敗下陣來。最直接的體現就是,已經有一些JDO的用戶對JDO的前景產生了動搖和迷茫,不少的JDO愛好者更是直言JDO將死。
不過對JDO來說,事情未必如此悲觀。因為新的持久層框架的最終發布最快也要在2005年夏天,這還是樂觀的估計,比較廣泛的使用則是2006年的事情了。并且如果新的持久層框架還是像EJB3 EntityBean那樣嚴重依賴J2SE5.0的annotation的話,無疑將無法在很多當前運行的系統和遺留系統上使用。這些都是JDO2的市場生存空間。有了這段時間的緩沖,JDO Vendor將可以平緩的轉變為一個J2EE1.5持久層框架的供應商,面臨更加廣闊的企業客戶群體。
TopLink是一個老牌的O/R Mapping軟件了,自從被Oracle收購之后,又增加了對Oracle數據庫的良好支持,和對Oracle AS EntityBean的支持。Oracle提供了TopLink的圖形設計環境,可以使得設計好的TopLink域模型既可以被單獨用在TopLink中,也可以被用在EJB CMP中。因此看來TopLink也走了一條和Hibernate同樣策略的路。
TopLink的問題在于相比Hibernate的開源和免費的優勢來說,TopLink既不開源,售價又不菲上。本來商業軟件TopLink應該在技術支持和商業宣傳策略上擁有足夠的優勢,然而Oracle公司畢竟是一個以數據庫為核心產品的公司,其他的一切產品都是為了數據庫銷售業績而服務的。在Oracle產品線中處于一個從屬地位的TopLink,由于先天不足,只能眼睜睜看著Hibernate的日益壯大而無所作為,因此TopLink更多的被局限在購買了Oracle數據庫,并且綁定Oracle數據庫的用戶群體中。
J2EE1.5的新持久層規范將毫無懸念的成為未來持久層框架的主流API,無論是Hibernate,JDO,還是TopLink終將兼容這個主流商業API。在當前的這三種持久層API當中,Hibernate無疑是最有前途的。這是因為:
1、新的持久層規范將基于EJB3.0 EntityBean規范,這意味著仍將以Hibernate的設計理念為基礎
2、JBoss對EJB3.0規范跟隨的步伐非常緊密,在規范制定過程中就不斷的發布參考實現產品,因此可以對對EJB3.0規范產生比較大的影響力。
3、根據內部泄漏出來的小道消息,BEA公司的WebLogic9產品線的項目經理已經在用Hibernate2來實現EJB3.0的持久層框架。WebLogic9 beta1預計年底發布,beta2預計明年3月發布,正式產品將緊隨EJB3.0規范正式版發布之后的明年秋季發布。
綜上所述,我們有理由對Hibernate的前途抱有強烈的信心。
最后的一個疑問是,既然J2EE1.5的新持久層框架可以脫離J2EE容器運行,那么大家不全部都去用Hibernate的后一套兼容API,而完全放棄Hibernate的原生API了嗎?那么是否意味著Hibernate做為一個獨立產品的使命徹底終結呢?
對于這個問題我的看法是:J2EE1.5的持久層規范要綜合各個EJB Vendor,JDO Vendor的意見,要平衡他們之間的利益得失,那么這樣一個瞻前顧后的規范必然無法覆蓋所有應用場合的全面需要,這不像Hibernate的原生API可以隨時根據開發人員的要求增加功能那么靈活。因此我預計Hibernate的原生API以其更加強大的功能仍然會吸引一大批人直接使用原生API,而不是兼容J2EE規范的API。
總而言之,對于我們當前的持久層開發來說,最好的辦法莫過于堅定的使用DAO層來隔離持久層和業務層邏輯,那么不管未來持久層風云如何變換,但凡基于POJO的持久層框架都可以被我們拿來任意替換。
轉載來源:
http://www.hibernate.org.cn/viewtopic.php?t=8146&postdays=0&postorder=asc&start=0