Bundle.update:模块化的一年

  • Alex Blewitt
  • 张龙

2010 年 1 月 27 日

话题:Java语言 & 开发架构

虽然目前正值假期,但自从上次的Bundle.update以来还是发生了很多事情。

dm Server 迁移到 Eclipse

最重磅的新闻当属 Eclipse Virgo项目提案(上周InfoQ 对此曾有过深入报道)。目前的 dm Server 版本是2.0.0,这也就意味着接下来的 2.1 版将在 Eclipse 下进行开发和发布。

现有项目与新提案之间的一个显著差别在于协议的不同。这意味着 dm Server 今后将基于 EPL 而非现在的 GPL,EPL 是一个更有利于商业行为的协议。此举的目的在于提升社区的贡献,同时鼓励这种软件开发方式。

目前的企业 OSGi 和 dm Server 引起了很多人的兴趣,围绕其的创新也一刻没有停止过。这种兴趣尤其以早期的使用者以及那些需求符合 OSGi Service Platform 动态模块特性的项目为甚。但对于主流的开发团队来说(只希望尽快构建好企业应用,麻烦越来越少),目前采用企业 OSGi 的代价可能会超出其短期的收益。在企业 OSGi 成为主流的企业应用开发方式事实上的标准前需要重点考虑这个问题。

介绍 OSGi 和 Equinox 的新书出版

本周出版了一本介绍OSGi 和 Equinox 的新书,这也是Eclipse RunTime系列书籍的第一本。本书介绍了如何通过 OSGi 构建模块化 Java 应用,虽然书中的示例基于Equinox,但对于那些想在其他 OSGi 平台上进行开发的开发者来说该书也是颇具价值的。

该书还从头到尾实现了一个Toast 示例项目,目的就在于通过具体的示例代码为该系列的后续图书铺平道路(这样读完此书的开发者就能很快上手其他书了)。本书分为四大部分:首先是 OSGi 概览、接下来是构建 Toast 示例指南、第三部分深入探索了 OSGi 的种种细节、最后是参考书目部分。

ECF remote services 开发完毕

近日,Eclipse Communications Framework项目实现了OSGi Remote Services规范,可以通过多种异构协议跨越 VM 连接 OSGi 服务,这些协议包括 REST、WS-*、JMS、XMPP、Skype 及一个 ECF Generic 实现。

不仅如此,还有多种不同的探测机制,比如 ZeroConf、SLP 以及静态的、基于文件的探测。

OSGi Remote Services 的 Apache Felix 实现也已经发布(Apache CXF),这也是 OSGi 的参考实现。但是该实现关注于通过 WS-* 传输层进行访问,而 ECF 则独立于传输层。不管哪种实现,最终用户和开发者所使用的 API 都是一样的。这样用户就可以在运行期对实现进行替换了。

Enterprise Expert Group 工作即将完成

近日,Peter Kriens 宣布 OSGi Enterprise Expert Group 即将完成,同时Enterprise Expert Group draft 4也于前不久发布了,该草案提供了大量的 Java EE 特性。我们有理由期待最终版将于今年 3 月发布,这正是OSGi DevConEclipseCon举办的时间。

EEG 将会提供新的查询机制以通过 OSGi 实现 JNDI 风格的查找、使用 JMX 管理 OSGi 运行时、通过 JTA、JPA 以及 DataSources 进行数据库访问,还会提供对 Remote Services 和 Service Component Architecture 的管理。此外,还将发布一种新的部署 bundle:WAB,这样 Web 应用 bundle 就可以像 WAR 那样被安装到容器中了。InfoQ 会在 EEG 发布其成果后对其进行深入报道。

WebSphere 发布 Alpha 版

IBM WebSphere 已经基于 OSGi 开发一段时间了,近日其发布了 Alpha 版的 OSGi 应用。该应用基于Apache Aries,同时包含了 OSGi Blueprint 容器(这类似于 SpringSource 提出的Eclipse Gemini)。这些项目都希望解决 JNDI 和 JTA 面临的一些问题,这也是 Enterprise Expert Group 重点要解决的问题。

这些容器都在拓展 OSGi 运行时的边界以容纳多个应用。未来将可以通过 OSGi Nested Frameworks对应用进行切分(类似于 Web 应用服务器切分 WAR 的方式)。但与 Web 应用服务器不同(WAR 被完全分离,无法共享代码),WAB 可以集成 OSGi 运行时,那时就可以像使用私有 bundle 和服务一样来轻松共享代码和服务了。

Tycho 使用 Maven 构建 OSGi

近日Sonatype发布了Tycho 0.6.0,使用的是新版 Maven 3。Tycho 是一套 Maven 构建器,可以根据 OSGi Manifest.MF 推断出依赖,而不是假想依赖存在于 Maven POM 中。这样就可以根据 POM 优先(在 Manifest 会自动生成的时候)或是 Manifest 优先的方式创建 OSGi bundle 了。

虽然使用 Maven 的大多数 OSGi 开发者(比如 Apache Felix下的开发者)更习惯于 POM 优先的开发方式,但 Manifest 优先的开发方式对此是个补充,可以通过 Eclipse PDE(Plug-in Development Environment)更加方便地开发 OSGi bundle。

在众多的 Eclipse 项目中,使用 Maven 而非 Ant 进行构建的有 EGit(http://www.eclipse.org/egit/http://www.eclipse.org/jgit/)和孵化项目Tigerstripe等。

Maven 项目正在朝 Maven 3 迈进,该版本进行了大量的重构,使用了Google Guice。此外,Maven repository(由Sonatype进行管理)的成功也用事实印证了使用多依赖的 Java 开发并不难。使用 OSGi bundle 仓库(比如OBRSpringSource 仓库)的人也越来越多,而且可以跨越不同的提供商进行分发。目前就提供一套统一的 OSGi 仓库(借助于Nexus,被 Tycho 所用)这个主题正进行一项探索性研究。试验仓库位于bundles.sonatype.orgosgi.sonatype.org。未来的目标是提供多种格式(OBR、P2 等等)的访问,这样 OSGi bundle 的使用就能像 Maven JAR 那样简单了。

Nimble 与 POSH

如果只是获取 OSGi bundle 的话,那么使用 OSGi bundle 解析器会是个比较好的选择。近日Paremus发布了Nimble——用于获取并下载 OSGi bundle 的解析器。

Paremus 将 POSH(Paremus OSGi Shell)绑定到了 Nimble 解析器上。这样就可以使用同一套命令初始化并管理一般的 OSGi 框架了(这么做可以简化 Felix、Equinox 及 Knopflerfish 的测试工作),再加上 Nimble 的帮助就可以很快启动 OSGi 运行时了,正如Dave Savage所述。通过下面这两行命令可以安装并运行基于 Spring 的 OSGi Web 应用:

posh -kc "repos -l springdm;add org.springframework.osgi.samples.simplewebapp@active"

open http://localhost:8080/simple-web-app/

感兴趣的读者可以到DZone上了解关于 Nimble 的更多信息。

OSGi UK User Group 及 OSGi DevCon London

OSGi UK User Group正在蓬勃发展,已经有 100 多名会员了。最近的一次讲座来自于 Marcel Offerman(来自Luminis)和 Graham Charters(来自IBM)。过几天其站点就会发布讲座的相关视频和材料了。

讲座的第一部分是对孵化项目Apache ACE的介绍,该项目旨在简化 OSGi 在多种设备上(包括远程)的使用。

在通过可重用组件组装软件的过程中,最难以解决的问题就是如何将软件部署到日益增长的连接设备上去。如果设备上的软件栈是异构的,同时需要不同的组件时情况会变得更糟。该讲座向我们介绍了如何基于 Apache ACE(开源、基于 OSGi 的解决)将软件组件分发到不同类型的设备上去,从移动电话到云中节点都有覆盖。

Apache Ace 项目基于 Luminis 去年初所捐献的软件,该软件已经应用到了不少真实项目中,如 On-ship Radar systems、field X-Ray Equipment、CMS 的软件更新与协议管理以及机场行李处理系统等。

第二个讲座介绍了 OSGi Remote Services(已经包含在了 OSGi 4.2 中)及其如何与 Service Component Architecture(SCA)进行交互,以Apache Tuscany为例进行讲解。

OASIS 一直在致力于开发 Service Component Architecture(SCA)规范。SCA 提供了一种异构的 SOA 编程模型,该模型跨越了众多的实现技术(EJB、BPEL、C++ 及 COBOL 等)、bindings(Web services、JMS、IIOP 等)和 policy(WS-Policy 等)。

该讲座对 OSGi Remote Services 和 Service Component Architecture 技术进行了简要的介绍,接下来谈到了如何将这二者整合起来让 OSGi 应用可以通过 Remote Services 访问多种 SCA 实现技术、bindings 和 policy 框架等。

即将到来的OSGi DevCon LondonJAX London已经宣布了大会日程安排。优惠到今天截止,但 OSGi UK User Group 成员可以获得额外的折扣。

总结

很明显,将有越来越多的大型服务器系统采用 OSGi,同时 OSGi 也开始向中小系统进军。随着构建工具的不断发展,开发者可以在多种 IDE 中开发 OSGi bundle 了;与此同时,用于共享 OSGi bundle 的新仓库也在不断涌现,模块化 Java 应用的开发将变得越来越容易。基于此,Kirk Knoernschild 断言:2010 将是 Java 模块化的一年

查看英文原文:Bundle.update: The Year of Modularity

Java语言 & 开发架构