Terry.Li-彬

虚其心,可解天下之问;专其心,可治天下之学;静其心,可悟天下之理;恒其心,可成天下之业。

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  143 随笔 :: 344 文章 :: 130 评论 :: 0 Trackbacks

来自:http://www.yeeyan.com/articles/view/60971/36275

简介

EJB 3是Java EE 5中获取提升最多的技术,在即将发布的Java EE 6中 EJB 3.1将进一步带给大家惊喜。Adam结合他的项目实践,在本文中详细列举了他所喜爱EJB 3的特性。

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

  1. 性能开销低。Glassfish v2中 只有大约3%.
  2. 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)模式不是线程安全的。
  3. EJB 3.0 支持 事务(transactional)。 所以只要成功调用了EJB方法,所有的资源将都是同步的(synchronized),比如写到数据库中的数据,发给服务器的消息等。容器会为你做到这些,你只要知道你所要做的是什么 (这和平台无关,但有时难以实现 :-))
  4. 在我所有的项目中都将部署描述符而替换成了annotation。这样就只有一个persistence.xml文件需要部署。EJB在重构,部署和移植方面都表现良好。
  5. EJB 3.0是真正可移植的(它可以让你中立于实现提供商和架构)。 相比EJB 2.1,这点更加突出,因为私有的部署描述符不再需要。实际上,EJB 3不再需要任何描述符。你只要部署干干净净的jar文件,然后附上在meta-inf中的persistence.xml,而其他都是可选的。
  6. 在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;

  7. Getters 和Setters方法是可选的: 不仅对于EJB,同样对于JPA。 资源可以直接注入到字段之中。
  8. 缺省和annotation的配置能够被XML描述符覆盖。而XML描述符不需面面俱到 - 你只要指定感兴趣的部分。你可以为某个特定阶段(比如测试、集成)开发通过XML描述对产品进行重新设置。
  9. 不需要特别的工具。你只需要annotation,一个Java 6 的编辑器和一个Jar文件。 无论是IntelliJ,Eclipse (含500附件的插件:-))还是Netbeans 6.1都对EJB 3提供了完善的支持,并对应用服务器也做了很好的集成,EJB的部署、取消部署、配置等都可以直接由IDE来管理。
  10. EJB 3.1可嵌入的特性很可能将获得支持。Glassfish v3已经对此提供支持。在GlassFish的测试中,我发现容器的启动只要令人惊讶的500ms。 此外,JBoss也支持可嵌入。
  11. EJB 3.1将提供许多有用的特性:Singletons (更便于配置和用于启动类等), 更好的timer支持 (cron-like),将来的异步方法,可选的local-interfaces 和基于WAR包的部署。
  12. 池的设置和线程池的配置对伸缩性的控制非常有帮助(除非容器崩溃,否则你不会为无法确定伸缩性而头痛:-))
  13. 和脚本语言交互的良好支持(包括JavaScript, Groovy)
  14. EJB是缺省可以被管理和监控的。EJB部署到容器后,你就可以对其方法调用和性能等进行监控。
  15. 不需事先依赖任何的架构和库等。ejb-jar和容器为你的应用代码打理一切,所以抛出像NoClassDefFoundErrors,ClassCastExceptions这样异常的可能会降到最低。
  16. EJB 3.0是超级紧凑的技术。实际上你已经不可能再为它做些什么简化 :-)。当然,这方面我也愿意听大家的意见。
  17. 他们非常容易测试-因为EJB就是一些类和接口。你甚至可以在容器之外启动它们。
  18. 即使最简单的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);
        }
     }

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

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

posted on 2009-04-18 11:19 礼物 阅读(291) 评论(0)  编辑  收藏 所属分类: ejb3.0