InfoQ

新闻

比较Eclipse扩展和OSGi服务

作者 R.J. Lorimer译者 宋玮 发布于 2008年1月29日 上午12时2分

社区
Java
主题
标签
OSGi,
Eclipse
Eclipse扩展和OSGi服务的本质及意图都非常相像。尽管它们很类似,但是由于它们背景不同,因此还是有很多不同点。Neil Bartlett曾经写了一篇文章,对Eclipse扩展及多种用途的OSGi服务进行了比较分析,最近,他又在其博客上以PDF的形式重新发布了这篇文章。这篇文章是特别为那些熟悉Eclipse注册库但不熟悉OSGi的Java开发者编写的。

比较开始于对常见混淆概念的解释,Eclipse扩展注册和OSGi服务层的共存导致了这些概念的混淆:
因为Eclipse在版本3.0中采用了OSGi运行时,在扩展注册(从一开始就是Eclipse的特性)和服务层(来自OSGi且先于Eclipse相关特性存在)之间就有了一些牵连。导致这种牵连的原因是这两种模型有些重叠,而且它们意图解决的问题都非常相似。然而常言道“the Devil is in the details(细节决定成败)”,这两种模型的差别还是非常大的,想将它们合并是不切实际的。因此,Eclipse plugin和RCP应用的开发者需要从这两者中做出选择。
Eclipse扩展注册基于的是定义在针对每个Eclipse plug-in的XML文件中的一系列条目。Bartlett描述了XML标记优于严格地使用可执行Java的各种好处。与Eclipse扩展相比,基础OSGi服务用规矩的Java代码来定义和注册,代码提供了多个行为实现。在描述到OSGi服务的时候,Bartlett解释了与Eclipse扩展相比其实现的内在区别以及相关的优缺点,并得出这一观点:
因此我们真正想要的是结合扩展和服务两者优点的某些东西。某些像服务一样是隐式动态的、但是像扩展一样是“按需”装载的东西。理想情况下,是可以简化应用程序开发者必须要编写的代码的某些东西。
那种认为Declarative Services可以满足各种情况的观点是不对的。因为Eclipse扩展和OSGi服务在不同的方面各有优缺点,创建Declarative OSGi Services是为了试图提供一种兼顾两种技术优点的方法。Declarative Services仍是相对较新的技术,适用于Eclipse3.3版(最新稳定版本),Declarative Services的初始版本已经可用了,可从Equinox下载站点单独下载

这篇文章的关键要素被总结成了一个用于比较的表格,该表格回答了Eclipse扩展以及所有以前描述过的各种OSGi服务(Services、Declarative Services、以及Spring-OSGi)的如下问题。
  • 什么是已注册的?
  • 它们是如何注册的?
  • 它们是如何消费的?
  • 什么是基数(cardinality)?
  • 它们何时被装载?
  • 怎样处理动态安装/卸载?
  • 缓存扩展/服务的引用会导致问题出现吗?
Neil Bartlett以如下看法作为文章的结论:
在这篇文章中,我已经概括地描述了Eclipse风格的扩展和OSGi风格的服务的优缺点。然而,我不希望我的读者不要单纯地认为“扩展不是动态的”或者“服务不能用于RCP应用”。恐怕这个问题太过敏感,根据你的需求的上下文自己做出评估是不可替代的。
想了解更多关于Eclipse Equinox和OSGi的关系,请访问Eclipse Equinox站点

查看英文原文:Comparing Eclipse Extensions and OSGi Services

1 条回复

回复

可以选择来用 发表人 Jili Lv 发表于 2008年1月30日 上午6时6分
  1. 返回顶部

    可以选择来用

    2008年1月30日 上午6时6分 发表人 Jili Lv

    OSGi服务的局限性比较大,没有Eclipse的扩展机制灵活方便,Eclipse扩展特别适用于静态配置.OSGi服务必须以对象的方式提供,但另一方面,它与最新的Spring-OSGi 1.0结合紧密.可以选择来用.至于DS,还没试过.

独家内容

剖析短迭代

敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?

应用JSF、Ajax和Seam开发Portlets(1/3)

本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。

AtomServer:数据分发的发布动力(第二部分)

在这篇文章里,Bryon Jacob和Chris Berry将和我们继续探讨AtomServer,它是基于Apache Abdera的完整Atom存储实现。作者还创建了几个Atompub规范扩展,其中包括自动标记、批处理和Feeds聚合。

架构师(试刊第二期)

InfoQ中文站的电子杂志《架构师》试刊第二期出版了!相比于上期,我们在内容的选择安排和版式上都根据读者的意见重新做了修正。“细节决定成败”,我们希望基于InfoQ中文站的专业内容,《架构师》能逐渐成为大家喜欢的电子刊物!

一种正规的性能调优方法:基于等待的调优

在本文中,Steven Haines探讨了Web应用性能调优问题。该领域过去更像是一门艺术而不是一门科学。他提出了一种称为基于等待调优的方法,使整个调优过程更加可度量,也因此更具科学性。

Java程序员ActionScript 3入门

通常来说,改变技术路线时最艰难的部分是辨别语言语法之间的不同。这篇文章就为Java开发者提供了一份如何转向Flex基础语言ActionScript的指南。

浅谈如何创建Rails应用

本视频主要以财帮子为例,介绍了如何创建一个PV为百万级的Rails应用。其中包括:Rails应用的服务器架构、Rails Cache的优化、负载均衡的处理、Web服务器的调试、分布式解决方案、Open API的设计等等。

Alexandru Popescu谈InfoQ.com网站架构

InfoQ首席架构师Alexandru Popescu在采访中谈论了InfoQ架构、Webwork与DWR、Hibernate与JCR、Hibernate可扩展性、最新的InfoQ视频流系统和InfoQ的未来规划。