为什么我喜欢EJB 3.0并且尤其喜欢EJB 3.1

http://developer.51cto.com/art/200906/127156.htm

Marc Fleury在2002年写了一篇值得一读的文章 蓝皮书 "为什么我爱EJB"  (下载),他的观点在当时是令人惊讶的。我那是已经在使用EJB,但并不真正地爱他们 :-)。我没有到哪个程度,但我真的喜欢EJB 3.0。原因如下:

◆性能开销低。Glassfish v2中 只有大约3%.

◆EJB 3.0是线程安全的(thread save)。这是一个巨大的优点。 每个线程所都拥有的实例,包括所有注入的资源比如实体管理器(Entity Manager),数据源(Data Source)和JMS,都是线程安全的。最棒的是:容器为你做到了这一切。你只需要一个标识(annotation),比如引用EJB的@EJB,获取持久化上下文的@PersistenceContext以及引用资源的@Resource :-))。更多讨论请参看"plain old Web Container" :-)(想想POJO-Plain Old Java Object,译者注)。提醒一下:Servlet作为一种单例(singletons)模式不是线程安全的。

◆EJB 3.0 支持 事务(transactional)。 所以只要成功调用了EJB方法,所有的资源将都是同步的(synchronized),比如写到数据库中的数据,发给服务器的消息等。容器会为你做到这些,你只要知道你所要做的是什么 (这和平台无关,但有时难以实现 :-))
在我所有的项目中都将部署描述符而替换成了annotation。这样就只有一个persistence.xml文件需要部署。EJB在重构,部署和移植方面都表现良好。

◆EJB 3.0是真正可移植的(它可以让你中立于实现提供商和架构)。 相比EJB 2.1,这点更加突出,因为私有的部署描述符不再需要。实际上,EJB 3不再需要任何描述符。你只要部署干干净净的jar文件,然后附上在meta-inf中的persistence.xml,而其他都是可选的。

◆在EJB 3 中,惯例优先原则(Convention Over Configuration)或正式地称为基于期望的配置( Configuration By Exception) ,它们和依赖注入(Dependency Injection) 的结合非常完美。大多数场合,开发EJB只需要少量的代码(比如没有"new"的调用,而只需要做个声明)

@Stateless
public class SampleBean implements Sample {
@PersistenceContext
private EntityManager em;

@EJB private Another anotherBean;

◆Getters 和Setters方法是可选的: 不仅对于EJB,同样对于JPA。 资源可以直接注入到字段之中。
缺省和annotation的配置能够被XML描述符覆盖。而XML描述符不需面面俱到 - 你只要指定感兴趣的部分。你可以为某个特定阶段(比如测试、集成)开发通过XML描述对产品进行重新设置。

◆不需要特别的工具。你只需要annotation,一个Java 6 的编辑器和一个Jar文件。 无论是IntelliJ,Eclipse (含500附件的插件:-))还是Netbeans 6.1都对EJB 3提供了完善的支持,并对应用服务器也做了很好的集成,EJB的部署、取消部署、配置等都可以直接由IDE来管理。

◆EJB 3.1可嵌入的特性很可能将获得支持。Glassfish v3已经对此提供支持。在GlassFish的测试中,我发现容器的启动只要令人惊讶的500ms。 此外,JBoss也支持可嵌入。

◆EJB 3.1将提供许多有用的特性:Singletons (更便于配置和用于启动类等), 更好的timer支持 (cron-like),将来的异步方法,可选的local-interfaces 和基于WAR包的部署。

◆池的设置和线程池的配置对伸缩性的控制非常有帮助(除非容器崩溃,否则你不会为无法确定伸缩性而头痛:-))

◆和脚本语言交互的良好支持(包括JavaScript, Groovy)

◆EJB是缺省可以被管理和监控的。EJB部署到容器后,你就可以对其方法调用和性能等进行监控。

◆不需事先依赖任何的架构和库等。ejb-jar和容器为你的应用代码打理一切,所以抛出像NoClassDefFoundErrors,ClassCastExceptions这样异常的可能会降到最低。

◆EJB 3.0是超级紧凑的技术。实际上你已经不可能再为它做些什么简化 :-)。当然,这方面我也愿意听大家的意见。

◆他们非常容易测试-因为EJB就是一些类和接口。你甚至可以在容器之外启动它们。

◆即使最简单的use cases也可以用EJB 3高效的实现。比如关于增删查改的 CRUD的例子:

@Stateless
public class CrudServiceBean implements CrudService<Integer,Customer> {

@PersistenceContext
private EntityManager em;

public Customer create(Customer t) { this.em.persist(t); return t; }

public void delete(Customer t) { t = this.em.merge(t); this.em.remove(t); }

public Customer find(Integer id) { return this.em.find(Customer.class, id); }

public Customer update(Customer t) { return this.em.merge(t); } }

◆他们工作的非常棒:近两年来,我在项目中使用EJB 3.0 + JPA 1.0。它们的出色表现不仅给我带来的惊喜,也给我们团队的带来了惊喜。

然而,Java EE6平台仍有可以提升的空间。JMS规范应该重新设计,让其更加“流畅”(fluent)。JNDI注册机制显得陈旧,有关JNDI的API的改进和简化将不仅有助于EJB的开发,而且整个Java EE平台也将因此受惠。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值