企业开发技术选型

企业级开发我们在开发前需要进行技术选型,选择合适的技术,会让我们事半功倍,这就是为什么站在巨人的肩膀我们会看的更远。下面是3年前写的,过了3年出现了很多新的技术和框架,我会尽快更新出最新的技术选型,希望对大家有所帮助。

2.1.基础架构

IOC Container:Spring, Guice

我们需要IOC Container的依赖注入作为胶水,把其他工具包粘在一起。还需要它的AOP,进行事务配置,权限管理。

这么多人都在使用Spring,实际使用中可以获得巨大的便利,如果选择了其他平台就要面临在关键时刻自己造轮子的窘境。使用Spring的实际经验更长,方便与其他组件整合。

Guice是由Google出品的,又使用了JDK5中的注解功能,问题是以后是否能得到很好的支持。

MVC:struts2, struts, JSF, RESTful Framework, SpringMVC

struts2比struts好用,在了解了OGNL的用法后,还是比较方便的。

struts毕竟还是老掉牙了。

JSF好复杂,没有IDE的支持基本没法用,看不清方向。

RESTfull Framework感觉太草率,有前途吗。

springmvc现在默认不包含在spring包中了,它的功能太简陋,有些新功能华而不实。

ORM:Hibernate, JPA, iBatis, JDBC

作为ORM方案,使用hibernate3对JPA的支持,使用annotation简化配置。

Hibernate用起来比较熟,支持多数据库,简化了数据库的操作,目前把所有调优的希望都放在二级缓存上了。

JPA对于规范不太了解。

iBatis据称是对JDBC的最简封装,但是与hibernate有太多的区别。

JDBC根本没进行封装,用起来风险太高。使用封装的框架更容易统一开发。

View:JSP-2.0, Freemarker, Velocity

严重偏向Freemarker,易用性,扩展性,自定义宏,还可以用在不支持JSP-2.0的服务器上,而且还可以与struts2配合。可是Freemarker并没有合适IDE配合,而且能够熟练使用的程序员也不多。

JSP-2.0功能明显不足,限制太多,不容易扩展,必须和taglib配合才能对付实际中的工作,taglib又太难写。

Velocity功能不如Freemarker。

Security:Spring Security, jsecurity, struts menu

Spring Security作为acegi的升级版本,更易用了,与spring整合在一起,控制权限。

jsecurity作为apache孵化器里的项目,有人对它进行了强烈推荐。

是否还考虑基于struts menu写一套自定义的菜单?

Ajax Widgets:ExtJS, Dojo, YUI, JQuery-UI

ExtJS轻便,好用,漂亮,功能强大。只是协议有问题。

Dojo笨重,难看,都不知道怎么用。

YUI是ExtJS的原型,但是封装没有ExtJS好。

JQuery-UI还很青涩。

如果不使用上述这类统一组件库,还可以选择jsCalendar这个日期选择组件,FckEditor和Tiny_mce都是富文本编辑器。据说专业人士喜欢用FckEditor,喜欢漂亮的都喜欢用Tiny_mce。JavaScriptTemplate可以批量生成HTML。和DWR结合实现上传进度条等功能。

JS Function Lib:Prototypejs, JQuery, Mootools

Prototypejs最老。对应的扩展主要有Script.Aculo.us。

JQuery有强力的查询能力。对应的扩展容易找到。

Mootools被fin强烈推荐,说OO封装做得很好,但感觉扩展组件不丰富。

JSON:DWR,json-lib

使用dwr和commmons-fileupload制作上传文件的进度条。

考虑使用dwr-2的服务器推,制作在线聊天。

与服务器之间交互采用json格式传递数据,目前采用的json-lib在处理循环引用的时候需要特别设置,否则在处理hibernate双向关联的时候100%出错。

2.2.扩展架构

在基础架构上进行的扩展,实现特定功能的工具:

WebService:CXF, XFire,Axis-2

Axis-2总感觉很笨重,而且不容易和Spring结合。

XFire已经停止开发,后来与Celtix合并为apache中的新项目CXF。

CXF是由Objectweb Celtix和Codehaus XFire合并成立的。与Axis1~2比较,更易于整合到Spring中。而且据说支持JAX-WS。不过不知道JAX-WS是干啥的。

工作流:Jbpm-3,Jbpm-4,Osworkflow

Jbpm-3是开源中比较火的框架了。但是spring-module-jbpm31封装的有问题,单元测试会报异常。

Jbpm-4太新,还是alpha版,而且改动太大了。

Osworkflow,号称最灵活的工作流引擎,据说所有实现都要自己写代码。

两者都支持Hibernate。

规则引擎:drools

据说是很轻量级的,拥有平民语法的规则引擎。

Search Engine:Hibernate-search,Compass,Lucence

Compass同另外一个Hibernate-search都是基于Lucence,对数据库的全文搜索引擎。

Compass开发的时间更长一些。Hibernate-search出现的时间还比较短,会用的人少,不知道前途如何。如果两者都不符合,还要考虑自己直接操作Lucence。

之前使用过Compass,在单元测试的时候会出现内存溢出的问题。

报表:JasperReport, BIRT, 自定义

JasperReport负责文本报表,JFreeChat图形报表。

虽然没使用过JasperReport,但已经听到过太多其他人对它的怨言了。

BIRT没有想像中那样好用,依赖那些eclipse中的包,显得太大了。

因为东西方习惯差异,自定义属于自己的一套报表应该可以解决国内很多问题。首选答案竟然是手写PDF和JFreeChat结合生成图表。

JMS:ActiveMQ, Jencks, Lingo

ActiveMQ是很多人推荐使用的JMS框架。

Jencks是一个JCA平台,可以提供J2EE里的资源容器。

Lingo据说可以把JMS封装成POJO。

定时调度:Quartz, java.util.Timer

据说Quartz是唯一免费的解决方式。这个组件放到web.xml里,可能造成内存泄露。robbin认为这种定时任务不应该和项目绑定在一起,而是应该建立一个单独的任务服务器。

如果是简单功能,也可以用JDK自带的Timer。

Cluster Cache:Open Terracotta

被许多公司使用,据说是很强大的分布集群策略。

JMX:Spring封装,MX4j

Java管理扩展,给人的感觉像是RMI一类的远程调用。

OSGI:equinox, felix

有点儿反感equinox的笨重,而且equinox是否能和eclipse分离呢?能否独立使用呢?能否能嵌入自己的项目呢?

felix是apache的项目,而且有maven插件,但是看了源代码之后,感觉太不成熟了。

动态语言:bsh, groovy, jruby, jython, rhino

bsh最简单,而且都是java语法,,功能也不多。

rhino只是解析js,也没什么特别功能。

groovy被期许了很大的希望,受到多方支持,有为数不少的组件,值得考虑一下。

jruby和jython的话,语法和java相差太大了,基本等于再学一门语言。

2.3.开发环境

JDK:5.0, 1.4, 6.0

5.0的那些特性还是很好用的,而且可以使用Retrotranslator把5.0编译的class转换成可以在1.4下运行的class。

推荐使用JRockit-27.2,据说可以解决sun jdk的perm gen内存不足问题。

6.0有点儿新了,怕出问题。

Servlet Container:Tomcat-5.5, Weblogic-9/10, Jboss, Geromino,Tomcat-6.0, Glassfish,Jetty, Resin

一般人还是用Tomcat-5.5,据说Tomcat-6.0支持OSGI了而且运行方式跟之前都不同了。

Jetty还是用在集成测试中。

之后的迭代里,应该兼容Weblogic, Jboss, Geromino, Glassfish。

数据库: Hsqldb, Mysql, H2database, Derby, Oracle, SQLServer

采用hsqldb作为嵌入式数据库,可与工程绑定发布,用户下载体验版后不需要额外安装数据库,减少了配置出错的机会。

考虑H2database和Derby,似乎H2功能更强力,Derby出身名门但是不支持commit是个问题。

Mysql是必须要支持的,因为是免费中使用特别广的。

SQLServer也是国内很多地方使用的中型数据库。

Oracle有很多人迷信,的确也是非常常用的大型数据库。

Hibernate本身支持多数据库,包括Mysql, SQLServer, Oracle等,未来替换成企业数据库也不是问题。

2.4.测试工具

单元测试:JUnit-3,JUnit-4, TestNG

JUnit-3。经典单元测试工具,应用很广,基本所有工具都支持。

JUnit-4有点儿新,新功能不太清楚。

TestNG据说很厉害,但不太熟悉。

js的单元测试工具jsunit不知如何应用。

Mock:EasyMock, JMock,Spring-test

EasyMock是老牌了,不需要继承特定的超类。

JMock需要继承特定超类,属于新框架。

Spring-test里提供了很多对付servlet里接口的测试类。它还提供了许多常用的测试基类,可以缓存xml配置并支持事务。

测试覆盖率:Cobertura,Clover

Cobertura发展至今,界面和功能已经接近Clover了,开源并且没有古怪的协议约束,Maven2上的配置也比Clover更简便。

Web集成测试:Selenium

Selenium是一款被众口称赞的集成测试工具,使用Firefox的插件录制测试,然后可以翻译成多种平台语言进行自动化测试。

同类产品还有httpunit和jwebunit。DBUnit可以帮助维护数据库中测试数据的完整,但是无法处理表间双向外键的情况。

可以使用Maven2插件进行测试,但是问题是一直没有发布1.0,一直只能使用1.0-SNAPSHOT。

WebService测试:SOAPUI

据说是唯一的WebService测试工具。

压力测试:JMeter

JMeter听过但是没用过。

2.5.项目管理

UML:Enterprise Architecture, Rose 2003, Visio, StarUML

EA不是免费的。

Rose是名门。

Visio是画图挺方便。

StarUML是免费开源方案。

项目部署工具:Maven2, Ant

Ant更灵活,但是对于大规模项目,自己写build.xml再配置所有的插件和各种流程太麻烦了。而且要借助ivy才好管理依赖。

或者在河边放下一盏写着心愿的河灯,祝愿一切安好。

企业开发技术选型

相关文章:

你感兴趣的文章:

标签云: