Java會(huì)因?yàn)镽oR的流行而過(guò)時(shí)嗎
在四年以前,當(dāng)我開始鼓吹Hibernate,抨擊EJB的時(shí)候,遭到的是群起而攻之的場(chǎng)面,但是不到一年之后,Hibernate已然得到了普及和大多數(shù)Java開發(fā)人員的認(rèn)可。
在三年以前,當(dāng)我開始贊譽(yù)spring的時(shí)候,spring還面臨著EJB3的陰影,以及EJB2對(duì)其不登大雅之堂的指責(zé),然而不到一年的時(shí)間,spring已經(jīng)成為絕大多數(shù)Java開發(fā)人員的首選。
在兩年以前,我極力希望宣傳webwork,唱衰JSF,時(shí)至今日,webwork以Struts2.0的身份容登大雅之堂,而JSF還在靠廠商死挺著。
而當(dāng)一年之前我開始采用RoR開發(fā)JavaEye的時(shí)候,RoR的置疑之聲還甚囂塵上,但當(dāng)我在今年初預(yù)言07年下半年RoR在國(guó)內(nèi)會(huì)被廣泛接受的時(shí)候,很多人已經(jīng)笑不出來(lái)了。
今年我預(yù)言些什么呢?我覺(jué)得會(huì)是AJAX技術(shù)走出PC的時(shí)代,證據(jù)就是iphone,與此相關(guān)聯(lián)的事情就是REST架構(gòu)的流行。
但是這篇文章里面我想談的卻不是我預(yù)言的水平準(zhǔn)不準(zhǔn),而是想談Java真的會(huì)因?yàn)镽oR的流行而過(guò)時(shí)嗎?目前在Web開發(fā)主要應(yīng)用在兩個(gè)大的領(lǐng)域,互聯(lián)網(wǎng)和企業(yè)應(yīng)用,我們分別來(lái)看一下:
一、互聯(lián)網(wǎng)領(lǐng)域
互聯(lián)網(wǎng)領(lǐng)域第一大動(dòng)態(tài)語(yǔ)言是PHP,第二、第三分別是ASP和Java。在中小型互聯(lián)網(wǎng)應(yīng)用當(dāng)中,PHP的王者地位不容動(dòng)搖,但在大型應(yīng)用當(dāng)中,Java是目前主流的選擇,特別是電子商務(wù)類型的應(yīng)用,例如阿里巴巴就從早期的PHP轉(zhuǎn)變到Java,從前的eachnet也是如此。造成這樣局面不是沒(méi)有原因的:
1、中小型互聯(lián)網(wǎng)網(wǎng)站強(qiáng)調(diào)開發(fā)速度,維護(hù)成本,以及入門快速和部署成本,PHP是最合適的選擇;用Java則顯得過(guò)于笨拙,開發(fā)慢,維護(hù)成本高,入門周期長(zhǎng),部署麻煩;RoR開發(fā)速度最快,維護(hù)成本最低,但是RoR入門速度沒(méi)有PHP快,部署成本比PHP高。因此中小型互聯(lián)網(wǎng)網(wǎng)站主流還是PHP,但RoR能夠占據(jù)一定的份額。
2、大中型互聯(lián)網(wǎng)站強(qiáng)調(diào)穩(wěn)定性,性能,大規(guī)模代碼的組織能力,而開發(fā)效率則退居次要地位,有些應(yīng)用如電子商務(wù)對(duì)事務(wù)有很高的要求,顯然Java是最合適的選擇;PHP的代碼組織能力最差,RoR次之。
在互聯(lián)網(wǎng)領(lǐng)域,Java從來(lái)就不是主流,并且Java的適用領(lǐng)域和RoR不太重合。我們甚至可以這樣說(shuō),RoR現(xiàn)在在互聯(lián)網(wǎng)領(lǐng)域取代的是那些原本不適合用Java,但是被錯(cuò)誤的選擇了Java的項(xiàng)目。
二、企業(yè)應(yīng)用領(lǐng)域
目前企業(yè)應(yīng)用領(lǐng)域第一大語(yǔ)言是Java,dotnet其次。企業(yè)應(yīng)用采用的技術(shù)和行業(yè)有很大關(guān)系:例如金融行業(yè),電子政務(wù)行業(yè)一般只采用Java。dotnet發(fā)展了6年尚且沒(méi)有進(jìn)入企業(yè)高端的應(yīng)用,RoR在短期之內(nèi)也很難取代Java的地位。
在企業(yè)應(yīng)用領(lǐng)域,Java是主流,并且Java的適用領(lǐng)域和RoR也不太重合。我們也可以這樣說(shuō),RoR將來(lái)在企業(yè)應(yīng)用領(lǐng)域要取代的是那些原本不適合用Java,但是被錯(cuò)誤的選擇了Java的項(xiàng)目。
至此,我想Java程序員大可以松一口氣,RoR目前有哪些不適合的場(chǎng)合呢:
1、對(duì)事務(wù)要求非常高的場(chǎng)合
RoR還是很簡(jiǎn)單的單數(shù)據(jù)庫(kù)事務(wù)控制,缺乏精細(xì)的事務(wù)控制功能,當(dāng)然也不支持跨數(shù)據(jù)庫(kù)的分布式事務(wù)。因此對(duì)于事務(wù)要求嚴(yán)格的大型電子商務(wù)網(wǎng)站,部署復(fù)雜的分布式數(shù)據(jù)庫(kù)場(chǎng)景顯得力不從心。當(dāng)然也許有些plugin可以提供這些功能,但是從目前的功能完備性和成熟度來(lái)看,還不夠。
2、處理大量遺留數(shù)據(jù)庫(kù)的場(chǎng)合
ActiveRecord的威力很大程度上來(lái)自約定,大量命名糟糕的遺留數(shù)據(jù)庫(kù)會(huì)對(duì)RoR造成比較大的障礙。
3、龐大的項(xiàng)目團(tuán)隊(duì),對(duì)開發(fā)速度要求低的場(chǎng)合
例如日本外包項(xiàng)目,團(tuán)隊(duì)龐大,個(gè)體開發(fā)速度要求低。但是對(duì)于代碼規(guī)范要求嚴(yán)格的項(xiàng)目。
備注:RoR是Ruby on Rails的縮寫。Ruby on Rails是一個(gè)用于編寫網(wǎng)絡(luò)應(yīng)用程序的框架,它基于計(jì)算機(jī)軟件語(yǔ)言Ruby,給程序開發(fā)人員提供強(qiáng)大的框架支持。Ruby on Rails包括兩部分內(nèi)容:Ruby語(yǔ)言和Rails框架。
【編輯推薦】