分享

SPRING与EJB:轻与重的思考

 五虎断门刀 2006-11-16
其实Spring和EJB争论起源于轻和重的讨论,我偶尔翻起多年前的米兰 昆德拉“生命不能承受之轻”这本书。

记得当时在大学(89年左右)时,一个高年级的“传道士”突然以“生命不能承受之轻”为口头禅,引起我们小辈的羡慕和纳闷,挺拗口的啊。他还说:比喻是一种危险的东西,人是不能和比喻闹着玩的。至此,我以后不敢随便用比喻,老实用逻辑推理来说事吧。

希腊哲学家巴门尼德和中国老子一样,把宇宙氛围对立统一的二元:明与暗;厚与薄;重与轻。

尼采认为永恒的轮回的想法是最沉重的负担,最沉重的负担压迫着我们,让我们屈服于它,把我们压到在地,女人总是渴望承受一个男性身体的重量,于是最沉重的负担同时也成了最强盛的生命力的影像。

负担越重,我们的生命越贴近大地,它就越真切实在。

世界上重的东西很多,艺术上,贝多芬的音乐是重的;软件上:EJB曾经是重的,在我们心目中,重好像代表正统,代表一种主导。

生活中承受沉重负担;软件开发中,过去EJB的学习开发调试都是一种沉重,在我们承受“这些”之重时,我们向往灿烂美丽的生活或软件之轻了。

而这时,曾经轻盈美丽的Spring走到大家面前,受到我们疯狂的欢迎,从此可以摆脱沉重的负担了。

巴门尼德也说:轻者为正,重者为负;我们甚至相信:轻量框架将取代重量,成为正统和主导地位。

但是,重的真的残酷; 而轻的真的美丽?

其实,当EJB 3.0推出;当Spring 2.0的程序需要特别的javac进行编译时,重和轻模糊了。

重和轻的对立是所有对立中最神秘、最模糊的。

J2EE提供了一套企业级Java应用框架(一种标准),是一种利用Java 2平台来简化企业解决方案的开发、部署和管理相关的复杂问题的体系结构。
J2EE使用多层的分布式应用模型,应用逻辑按功能划分为组件,各个应用组件根据他们所在的层分布在不同的机器上。J2EE的初衷正是为了解决两层模式(client/server)的弊端,在传统模式中,客户端担当了过多的角色而显得臃肿,使用J2EE 的多层企业级应用模型将两层化模型中的不同层面切分成许多层。一个多层化应用能够为不同的每种服务提供一个独立的层,以下是 J2EE 典型的四层结构:
运行在客户端机器上的客户层组件
运行在J2EE服务器上的Web层组件
运行在J2EE服务器上的业务逻辑层组件
运行在EIS或数据库服务器上的业务信息系统


J2EE为搭建具有可伸缩性、灵活性、易维护性的商务系统提供了良好的机制:
保留现存的IT资产: 由于必须适应新的业务需求,利用已有的信息系统方面的投资,而不是重新制定全盘方案就变得很重要。这样,一个以渐进的(而不是激进的,全盘否定的)方式建立在已有系统之上的服务器端平台机制是我们所需求的。J2EE架构可以充分利用用户原有的投资,如一些公司使用的BEA Tuxedo、IBM CICS, IBM Encina,、Inprise VisiBroker 以及Netscape Application Server。这之所以成为可能是因为J2EE拥有广泛的业界支持和一些重要的‘企业计算‘领域供应商的参与。每一个供应商都对现有的客户提供了不用废弃已有投资,进入可移植的J2EE领域的升级途径。由于基于J2EE平台的产品几乎能够在任何操作系统和硬件配置上运行,现有的操作系统和硬件也能被保留使用。

高效的开发: J2EE允许把一些通用的、很繁琐的服务端任务交给中间件供应商去完成。这样开发人员可以集中精力在如何创建逻辑上,相应地缩短了开发时间。高级中间件供应商提供以下这些复杂的中间件服务:
1.状态管理服务 -- 让开发人员写更少的代码,不用关心如何管理状态,这样能够更快地完成程序开发。(注:指有态会话Bean,而Spring目前没有提供这样的状态管理服务,Jdon框架则提供了)
2.持续性服务 -- 让开发人员不用对数据访问逻辑进行编码就能编写应用程序,能生成更轻巧,与数据库无关的应用程序,这种应用程序更易于开发与维护。 (注:这就是说为什么说数据库时代终结了)
3.分布式共享数据对象CACHE服务 -- 让开发人员编制高性能的系统,极大提高整体部署的伸缩性。(Spring没有提供缓存,jdon框架提供了,而EJB提供了强大的分布式缓存,当然今天我们可以将JBoss的POJO 分布式缓存分离出来,用在Spring或Jdon框架上,但是这些需要你的定制能力)

支持异构环境: J2EE能够开发部署在异构环境中的可移植程序。基于J2EE的应用程序不依赖任何特定操作系统、中间件、硬件。因此设计合理的基于J2EE的程序只需开发一次就可部署到各种平台。这在典型的异构企业计算环境中是十分关键的。J2EE标准也允许客户订购与J2EE兼容的第三方的现成的组件,把他们部署到异构环境中,节省了由自己制订整个方案所需的费用。

可伸缩性: 要选择一种服务器端平台,这种平台应能提供极佳的可伸缩性去满足那些在他们系统上进行商业运作的大批新客户。基于J2EE平台的应用程序可被部署到各种操作系统上。例如可被部署到Linux、或UNIX与大型机系统,这种系统单机可支持64至256个处理器。(这是NT服务器所望尘莫及的)J2EE领域的供应商提供了更为广泛的负载平衡策略。能消除系统中的瓶颈,允许多台服务器集成部署。这种部署可达数千个处理器,实现可高度伸缩的系统,满足未来应用的需要。

稳定的可用性: 一个服务器端平台必须能全天候运转以满足需求。因为INTERNET是全球化的、无处不在的,即使在夜间按计划停机也可能造成严重损失。若是意外停机,那会有灾难性后果。J2EE部署到可靠的操作环境中,他们支持长期的可用性。一些J2EE部署在WINDOWS、Linux环境中,也可选择健壮性能更好的操作系统如Sun Solaris、IBM OS/390。最健壮的操作系统可达到99.999%的可用性或每年只需5分钟停机时间。这是实时性很强商业系统理想的选择。

基于构件:它特点是编译码、独立部署的单位、由第三方进行组合的单位、无持久状态等,它具有可插入、更好的设计、更好的复用、方便的更新、实现与接口分离的优点。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多