OpenEJB 3.0 支持对枚举和集合的依赖注入及 OSGi 和 EJB 3.0 特性

  • Srini Penchikala
  • 张龙

2008 年 5 月 7 日

话题:Java语言 & 开发

开源轻量级 EJB 实现框架OpenEJB的最新版支持对枚举、集合和 Maps 的依赖注入(Dependency Injection,即 DI),并且支持 OSGi 和 EJB 3.0 规范。在经历了一年半的开发后,OpenEJB 3.0 最终版近期发布了。该版本还支持 @EJB 引用其他 EAR 文件中的本地接口、事务日志及基于 HTTP 协议的 EJBd,同时它还支持 EJB 3.0 的新特性如 Business Interfaces、Java Persistence API (JPA) 及JAX-WS Web Services。

该新版本包含一些代码改进和 bug 修复,你可以在 OpenEJB 站点的发布文档中找到这些列表。Alexander Saint Croix 最近撰写博文列举出了该版本的新特性、改进及 bug 修复。

OpenEJB 使用了其他一些开源框架,如使用OpenJPA提供 JPA 和 CMP 的持久化、使用ActiveMQ处理 JMS/MDB、使用Apache CXF实现 JAX-WS 特性。OpenEJB 的一些特性主要瞄准了EJB 3.1 规范,如Collapsed EAR(在同一个归档及 classloader 中共存的 ejbs 与 servlets)及针对单元测试的嵌入式 EJB 容器。不仅如此,即将成为JavaEE 6组成部分的 EJB 3.1 Lite profile 非常类似于 OpenEJB。

与 Java EE 容器的集成: 

OpenEJB 3.0 可以插件的方式集成到Tomcat 6服务器中,这就在 Web 应用中增加了对 EJBs 的支持。将 OpenEJB 加入到 Tomcat 中可以为 Servlets 提供新的 Java EE 5 能力,如 JPA、JAX-WS、JMS、J2EE 连接器及事务。OpenEJB 天生就提供了对Glassfish部署描述符、Geronimo及部分WebLogic部署描述符的支持。

OSGi 支持:

OpenEJB 框架是作为一个OSGi包发布的,这意味着所有 OpenEJB 3.0 的二进制文件与 OSGi 元数据一起被提供并且可用于任何 OSGi 平台上。基于 OSGi(使用Apache Felix构建)的开源 ESB 框架ServiceMix 4将把 OpenEJB 作为 ServiceMix 的一部分。

OpenEJB 项目创始人之一的 David Blevins 撰写博文记录了该项目的再生最新发布。InfoQ 采访了 David 以更深入了解 OpenEJB 3.0 的特性及项目未来的路线图,尤其是它将如何支持 EJB 3.1 规范。

对企业级 Java 开发者来说,在 EJB 中支持对枚举和集合对象的依赖注入意味着什么呢?它是如何帮助 EJB 组件的设计和开发呢? 

关键在于这使得 EJB 开发者(或者在 Tomcat 中使用 OpenEJB 的 Servlet 开发者)能真正深入到 JavaEE 的依赖注入功能,并且使之成为自己的东西。枚举、类和集合是我们所增加的额外的内建类型——我们期待在 Java EE 6 中也能具备这样的类型。此外,我们支持在应用中通过使用java.beans.PropertyEditor实现对任何你所创造对象的注入。这些增强使你能扩展注入以包含你的对象和资源并且使得 Java EE 作为一个通用的 DI 框架具有更好的可用性。

关于在 Java EE 容器外 OpenEJB 框架提供了何种测试驱动开发以支持对 EJB 的单元测试的问题,David 谈到了 OpenEJB 的嵌入式测试功能。

你可以写一个普通的单元测试以调用 EJBs,就像其他 EJB 客户端所做的那样。区别在于容器和 EJBs 就运行在你单元测试的 VM 中。我们会对应用的 classpath 进行调整使之适应于测试用例,这样你就可以通过 JNDI 查找你的测试用例了。你只需针对本地容器和远程容器分别使用一个不同的 InitialContextFactory,然后就可以相同的方式操作一个嵌入式数据库了。通过这种方式你可以测试 EJBs 的方方面面,没有任何局限性。畅想一下,你可以测试 webservice、Stateful bean 及扩展的 EntityManager,或者测试带有JTA EntityManager 的 Stateless bean 并且测试用例运行于一个事务之内。这也是我们期望在 EJB 3.1 中能看到的一个特性。

你能详细说明 OpenEJB 3.0 提供的 OSGi 支持以及以 OSGi 包的方式使用 OpenEJB 产品意味着什么吗?

当前 OSGi 支持适合使用 OSGi 平台的人,他们渴望以包的方式增加 OpenEJB 以获得 EJB 支持,或者由类似于Apache ServiceMix这样的项目所驱动的人,该项目做的就是提供 EJB WebServices 支持。OpenEJB 可用的含有 EJB jars 的所有包都将被部署。

OpenEJB 3.0 能通过 HTTP 协议调用 EJB,这听起来非常棒。你能否更深入地解释一下该特性及其背后的动因?

其动因就是让人们能绕过防火墙的限制并使 Tomcat/OpenEJB 用户可以通过一个单一的端口来运行 ejbs 和 servlets。这是由一个 Servlet 驱动的,你可以将其加到任何应用中,也可以删除它,还可使用 SSL 等等。最终的目标就是提供 RESTful ejb 调用。在未来的 3.x 版本中你会见到它。

Java EE 6 会将 EJB 3.1 规范作为其一部分。在该版本之后,OpenEJB 团队有什么计划以支持 EJB 3.1 呢?

OpenEJB 已经是 EJB 3.1 预览版的一个不错的来源了,比如这里提到的特性以及在 1.0 版中推出的 WARs 中的 EJBs 特性等。我积极参与了 EJB 3.1 专家组的工作并且对工作的进程及 OpenEJB 所做的贡献感到兴奋异常。我们希望能再接再厉并在最终规范发布前提出其他建议如单例及异步 beans。

OpenEJB 项目对于新特性和未来的增强方面的路线图是什么?

既然这些特性的时间表已经公布出来了,我们期望看到更多 EJB 3.1 相关的特性以预览的方式呈现出来,如 @Singleton 和 @Asynchronous、没有接口的视图(the no-interface view)。嵌入式支持和 Tomcat 集成总是在不断被调整和扩展。我们在以下方面一直在不懈努力:集群、CMP/JPA 适配器的进一步优化、将 EJB 2.x 应用转化为 EJB 3.0(实际上是根据部署描述符增加了注解)的 Eclipse 插件、通过备选JAXB实现产生优化的代码改善主要的 WebServices 性能。

可以从 OpenEJB 站点下载OpenEJB 3.0。OpenEJB 开发团队还提供了很多 EJB 示例以帮助开发者学习该框架的使用。

查看英文原文:OpenEJB 3.0 Supports DI of Enums and Collections, OSGi and EJB 3.0 features

Java语言 & 开发