J2EE .NET宠物店大战

转载 2006年05月22日 15:58:00

相信大家常常会看到很多统计数字,来自各家厂商、各种传播媒体、各个政治团体,但是数字虽然会说话,却常常各说各话。前阵子出现一篇比较微软.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

java 宠物店管理系统

项目需求: 1. 完成宠物管理系统!    1. 新建一个Pet类       1. 属性:          1. 名字String name          2. 性别 char se...
  • benxiaohai888
  • benxiaohai888
  • 2017年08月05日 21:06
  • 1760

练习:简单实现坦克大战

选择这个项目作为swing部分的总结 1.添加窗体,设计图型界面2.设计一个绘制坦克的类3.设计一个绘制子弹的类3.编写一个坦克主类,子类敌方坦克,我方坦克4.编写一个子弹类5.考虑窗体的重绘...
  • break1914
  • break1914
  • 2017年11月03日 14:26
  • 207

Java学习总结之坦克大战项目(完结版)

V1.0:
  • u011648768
  • u011648768
  • 2013年09月20日 12:21
  • 2407

Unity3D项目之《坦克大战》

2016年2月4日11:00:27 Tank_Project_Log 新年之前,记录一下Unity3D项目之坦克大战游戏经过,迟迟到过完年才完成发布,实在实在拖延症太重。...
  • six_sex
  • six_sex
  • 2016年03月02日 23:21
  • 11585

Unity3D之太空大战一

这是一个简单的太空大战DEMO,整个游戏两个部分,开始游戏界面跟游戏主界面,...
  • kuloveyouwei
  • kuloveyouwei
  • 2014年07月20日 15:53
  • 6564

坦克大战项目总结

2016/6/27   首先对于此次项目,属于游戏类,并且是游戏中的一个经典。对于不少人来说,这个游戏带有儿时的记忆,所在完成这个项目的时候,尽可能的做到高度还原的状态。   所以在做游戏项目...
  • culous
  • culous
  • 2016年06月27日 23:37
  • 1350

【Java_项目篇<1>】--JAVA实现坦克大战游戏--画出坦克(一)

为什么选择这个项目? 1.好玩,有趣 2.涉及到java基础的各个方面的技术: 面向对象思想、多线程、IO、绘图技术、监听事件、数据库、界面编程 3.巩固旧的知识 黑色框为JFrame 红...
  • qq_24653023
  • qq_24653023
  • 2016年08月16日 22:43
  • 8615

自学 Python --飞机大战

gif 好像看起来有点卡哇, 这是自学Python的第一个实战小玩具,嗯,写游戏确实比玩游戏有意思多了,fafafa 嗯,开始吧 ,源码放在了我的github,源码中包括了素材文件,自...
  • qq_16666847
  • qq_16666847
  • 2017年11月27日 15:37
  • 334

Qt游戏编程——飞机大战——补充

承接上篇: http://blog.csdn.net/hao_zong_yin/article/details/74540652 补充包: #ifndef SUPPLY_H #define ...
  • hao_zong_yin
  • hao_zong_yin
  • 2017年07月06日 16:17
  • 735

js实现的飞机大战

1.html代码 开始游戏 分数: 0 继续 重新开始 回到主页 飞机大战分数 0 继续 2.js主要代码 //获得主界面 var mainDiv=doc...
  • qq_28292937
  • qq_28292937
  • 2016年07月26日 17:41
  • 3442
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:J2EE .NET宠物店大战
举报原因:
原因补充:

(最多只允许输入30个字)