J2EE .NET宠物店大战

相信大家常常会看到很多统计数字,来自各家厂商、各种传播媒体、各个政治团体,但是数字虽然会说话,却常常各说各话。前阵子出现一篇比较微软.NET和Java J2EE架构执行效率的报告,常常被微软阵营拿来当成打击J2EE的证据。例如以下这段话﹕

"而据微软宣称,Visual Studio.Net能支持25种语言,和Java相比具有节省2/3程序代码、效能快28倍,承载六倍的使用者的功能"
- 摘自台湾CNet 2002年四月二日新闻专区

这样超能力的.NET效能报告到底来自何方?其真实性为合?本周我就来
从头开始讲讲这个精采故事的始末。

J2EE (Java 2 Enterprise Edition)是Java技术在企业运算上的应用,之中包含多种运算标准,EJB组件架构、JDBC数据库运算、JMS讯息传递、Java Servlets/JSP等Web组件程序等等,功能强大但是内容博大精深,为了让使用者可以有一个设计J2EE架构应用程序的模板,Sun做出一套系统名为 "Java Pet Store"。这个线上宠物店的范例是针对已经熟悉Java程序设计和J2EE观念的人,提供一个用正规方式设计出来的系统,让要用J2EE架构的人有一个参考的依据。

这个范例一出来,很快就被用来当成比较各家J2EE兼容产品的依据。最先是在去年的JavaOne大会上,受邀参加主题演讲的Oracle大老板Larry Ellision重炮轰击在他之前刚讲完下台的BEA,公开宣称Oracle的J2EE Application Server (Oracle9iAS) 的执行效能是BEA WebLogic的三倍,同时也是IBM WebSphere
的两倍。接下来IBM和BEA都站出来反击,例如BEA在去年七月也公布一项效能数据,数据上显示WebLogic Server 6.1的执行效率是IBM WebSphere的四倍,并且比Oracle的产品快上54%等等。这种情况其实是正常的,Java标准的精神原本就是各家厂商合作制定技术标准,然后再来根据这个标准来比赛谁的产品做得好。但是正当各家J2EE厂商比较得正热闹的时候,却半路杀出一个程咬金,微软有个网站叫做GotDotNET公布一份报告,宣称他们用同样的架构运用.NET技术做出同一套系统,结果就是本文一开头的那一段︰"和Java相比具有节省2/3程序代码、效能快28倍,承载六倍的使用者的功能"。这个数字一公布,就常常被微软以及微软的经销商们拿来当成.NET远远超越J2EE的证据。

这种惊人的数据当然引起J2EE阵营的质疑,于是大家仔细去看到底这些数字是
怎么产生的,很快地就被发现其中大有文章。这个.NET版本的宠物店系统已经被从头到尾改装过,整个架构都跟原先Java Pet Store不一样。根据网络上来自各方的整理,主要的不同点有以下几个﹕

1. Java Pet Store用的架构设计是所谓的MVC design pattern。MVC是Model-View-Controller的简写,是design pattern的一种,源自Smalltalk。以往开发这种大型应用程序常常把不同用途的各部分程序都混在一起,造成项目成员分工不清,系统也很难维护。MVC design pattern则是将对象分成三类,Model对象专门用来包装应用程序的状态,View用来负责屏幕上的展现,Controller则负责定义应用程序的各种动作和反应。Java宠物店系统利用MVC Pattern设计整个系统架构,将各层的对象清楚地分开。.NET的宠物店则是完全采用自己定义的架构,所以在一开始就和原来的范例完全不一样。

2. 在资料存取方面,.NET宠物店大量使用数据库中的store procedure。但是在原来的Java宠物店中,这些商业逻辑的工作是放在中间层组件中的。把这些工作放到store procedure里也许可以增加一些执行效率,但是却牺牲了程序的弹性和把各种工作都放进store procedure里, 带来的缺点是维护不易。而且对于某些阳春型的数据库系统 (例如MySQL),它根本就没有store procedure的功能。

3. 在数据库方面,.NET宠物店采用ADO.NET的Sql DataReaders来存取微软SQL  Server的资料。但是如果数据库换成其它厂牌的产品,比如说 Oracle、
   Sybase或是DB/2,虽然还是可以用 ADO.NET透过 OLE DB以及ODBC等方式来存取,但是在效率上就不可能跟在Microsoft SQL Server上一样了。所以Java宠物店是一个不管使用各家产品皆可行的展示,.NET宠物店则是在各方面都采用自家产品/技术的产物。

4. 另外.NET宠物店还有一个最快速提升效率数字的方法,就是去更改SQL的
   query statement,让传回来的资料笔数少一些。这招果然有立竿见影的效果 :)

简单来说,这个.NET版本宠物店和Java宠物店的最大差别在架构设计。Java宠物店的目的是展示一个具扩充性的企业运算架构,就是采用三层(3-Tiers)式设计,资料展现层在最外面,中间是执行企业运算逻辑的中间层组件,后端就单纯是存放资料的关系型数据库。如此一来工作分得很清楚干净,各司其职。而微软的.NET宠物店其实就类似传统的两层式(2-Tiers)设计,

另外Java宠物店当初的用意也只是当成一个J2EE架构设计的模板,并没有特别针对加速执行效能作额外的设计。但是.NET宠物店完全以执行效能出发,为此不惜重新量身订作,虽然系统跑起来外观和功能一样,但是里头完全不是那么回事。如果用它来展示.NET也可以做出一套相同的宠物店系统那倒无妨,但是如果用执行效率来作文章,那就有些不公平了。

近来最新的发展是Sun的Java/XML部门总裁Rich Green在JavaOne大会上宣布,Oracle和IBM又针对Java宠物店在不更动架构下做了效能提升,结果比.NET宠物店快上18到22倍。比如说在中间层的EJB组件之中,它们使用 isModified() 方式来避免不需要的数据库更新动作,这个小更动就大幅提升了整体的执行效率。而且为了系统的架构弹性和程序可移植性,在这个新版的系统中仍然没有像.NET版本一样使用store procedure。Oracle的这篇最新报告和原始码可以在下列网站下载﹕

http://otn.oracle.com/tech/java/oc4j/content.html

另外在TheServerSide网站上也有一位先生发起在不牺牲原来架构和弹性的前提下,来做一套也在执行效能上作最佳化的无敌终极版Java宠物店。也有人干脆仿效.NET宠物店的方式,干脆弄一套两层式(2-Tiers)的Java版宠物店,和用微软的范例系统 "北风数据库" 同时摆在网站上让人做线上比较。它们的网址分别是︰

http://www.javelinsoft.com/petstore
http://www.javelinsoft.com/northwind

相信这个宠物店大战还没完,J2EE各家厂商、网络上Java阵营的支持者、加上.NET阵营,都会继续改进自己做的系统,并公布更加梦幻的数据。一般使用者要注意的就是不要被简单的数字所蒙骗,不要跟着瞎起哄。要看看到底它做了哪些修改才得到这样的效能提升,而且效能不是一切,系统的稳定度、架构的弹性和程序可移植性、程序维护上面的难易度,都是要一并考量的因素。而且既然要比赛,立足点就得公平,不然好比奥运游泳比赛,大家都照规矩在水中划手踢腿游,但是偏偏有一个人为了速度,在屁股上装个推进器往前射,然后再来自己宣称打破世界纪录,还有一帮人在旁边跟着鼓掌叫好,这样子就不太对了。

下面是本文中提到的文章网址,有兴趣进一步研究的朋友可以自行参考﹕

Java宠物店的原始网址 (包含所有文件和范例程序代码)﹕
http://java.sun.com/blueprints/code/index.html#java_pet_store_demo

Sun有关这个Java宠物店系统的FAQ︰
http://java.sun.com/blueprints/qanda/faq.html

解说 MVC Pattern的文件︰
http://java.sun.com/blueprints/patterns/j2ee_patterns/model_view_controller/index.html

.NET版本宠物店的网址︰
http://www.gotdotnet.com/team/compare/petshop.aspx

Oracle版本Java宠物店的网址﹕
http://otn.oracle.com/tech/java/oc4j/content.html

BEA版本Java宠物店的网址﹕
http://www.bea.com/press/releases/2001/0709_benchmark_bea-ibm-oracle.shtml

IBM对.NET提出的响应︰
http://www-3.ibm.com/software/webservers/studio/msnetreview.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值