今天在写方案时,手边正好有一份2002年的电子政务方案,其中提及使用J2EE的优点和特点,我觉得今天拿出来重温一下还是很有意义的,当然文中的观点都是当初EJB的主要优点;虽然今天构件技术发展迅速,但是温故而知新,当初为什么我们需要EJB?EJB给我们什么优点。
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分钟停机时间。这是实时性很强商业系统理想的选择。
基于构件:它特点是编译码、独立部署的单位、由第三方进行组合的单位、无持久状态等,它具有可插入、更好的设计、更好的复用、方便的更新、实现与接口分离的优点。
索性来个2005该话题的总结:
Java企业系统架构选择考量:
http://www.jdon.com/artichect/java_ee_architecture.htm
J2EE集群原理:
http://www.jdon.com/jive/article.jsp?forum=121&thread=22282
Spring vs. EJB
http://www.jdon.com/jive/article.jsp?forum=16&thread=18904
好像上面话题讲EJB比较多,本身就比较沉重,但是有人甚至说J道是绝对推荐重型的;那么又有些片面了。
Jdon框架在2005中主要进步是构造轻型框架,可以说是试图结合EJB和Spring的优点,还有经典软件Jive。从论坛上看,很多初学者几乎能很快跑通Jdon框架的应用系统;付出较少的学习成本;得到快速成型的小型应用系统,Jdon框架绝对定位在轻盈浪漫的小夜曲,它和重型的EJB有良好的沟通桥梁;它不必象Spring那样声嘶力竭地呐喊,试图从EJB手中争夺更多的市场。
但是,无疑,Spring在现代构件方面是起着领头羊和探索者的角度,在新年开始之时,他们是值得尊敬的。