InfoQ

新闻

JSR277和OSGi会结合吗?

作者 Alex Blewitt译者 张龙 发布于 2008年5月21日 上午7时39分

社区
Java
主题
技术,
语言
标签
OSGi,
JSR 291,
JSR 277,
JSR 294

上个月的一篇新闻谈及了JSR277和OSGi(即JSR291)的状况,这在JSR277专家组邮件列表引发了一场激烈的争论,这场争论是今年以来最为激烈的一场。这之后的主要推动者之一就是Bryan Atsatt,他是JSR277(模块)和JSR294(超级包)的专家组成员。他说JSR277可以胜过OSGi

初始规范实际上包含两个独立的部分:一个api/框架,一个带有新的分发格式的实现。不幸的是,人们总是不加区别地介绍他们。更遭的是,新的分发格式(“.jam”文件)经常占据上风。
那么JSR 277如何胜过OSGi呢?通过向SE环境提供紧密的集成。其优势主要体现在以下四个方面:
  • 正则存储模型
  • 编译期依赖的决定
  • 跨模块实现的类/资源共享
  • 通过命令行的执行
对于现存的OSGi包来说这些都可行。还能更好点吗,哼?也许还有希望。

事实上,Bryan已经在JSR277专家组中发表了大量的评论;他提出规范应该与实现相分离,因为在专家组的草案介绍中它们已经混淆在一起了;另外他又提出Peter Kriens应该加入进来

专家组已经深陷泥潭了,我们需要重新步入正轨。我提出以下具体步骤:

  1. 让Peter Kriens加入到专家组中。Peter在这个领域具有丰富的经验,我相信他很快就会成为一个有价值并且活跃的贡献者。
  2. 将设计/讨论/调查的互动过程搬出Sun的办公室,搬到专家组中。
  3. 给予专家组更多一手信息(或者至少一个快照)。

当然,看起来很多讨论和实现的决定都是在Sun公司里闭门造车,在决定制订出来后,只是把专家组看作是证明该决定的读者。事实上,以上这两点正是导致Peter Kriens不想加入的罪魁祸首

然而,JSR 277现在包含两个好的(资源库和语言模块)和一个坏的(JAM)部分。就在JavaOne 2008之前,Stanley发布了一个简短的OSGi互操作性文档。这个文档不仅在细节上非常简略,而且还提到了尚未公布的早期草稿#2(EDR2)的很多地方。我问了专家组成员BJ Hargrave [Equinox - ed]和Richard Hall [Felix - ed]是否他们看到了这个草稿,然而他们也并未看到。最近我在JSR 277邮件列表中抱怨缺乏讨论,看起来工作都在暗地里进行。

在Alex和Stanley介绍JSR 277的过程中,我清楚地认识到幕后已经做了很多工作了;而这一切并未在邮件列表上进行过任何交流。对于在座的各位并不知道几乎所有的东西都没有经过专家组的讨论。如果唯一的选择就是同意Sun在幕后所做的工作的话,那我加入专家组还有什么意义呢?如果在JavaOne演示的尚未发布的EDR2成为JSR 277最终的结果时,有多少东西需要改变?当大部分工作已经完成时,我还需要加入专家组吗?在这种情况下,你能完成多少基本的改变?

我们现在处在一个关键时期。尽管我很想参加关于Java语言模块和仓库的讨论,但是我不能对Java中的模块系统负责,因为它毫无道理地搞出这么多复杂的东西出来。我真心希望Sun能抓住这救命稻草,放弃JAM,采取更为简单的方式在整个系统中使用OSGi元数据。这是我在过去的几个月中得出的结论!

同时,Sun的不断创新也意味着OSGi的交互正在不断进步。Alex Buckley已经加入了277专家组(负责上述的JSR294的简化工作,这真是可喜可贺啊);同时Mandy Chung已被赋予OSGi互操作性方面的工作

看起来Sun已经在关注了,还算及时。在今年的JavaOne上,我们报道了基于OSGi的Spring Source应用平台运行在OSGi上的GlassfishOSGi最佳实践展示(PDF)激起了人们的兴趣,自从JavaOne后,在论坛和博客上关于包(bundles)的讨论就在持续增长。我们希望JSR277 EDR 2会牢记这些建议并且将OSGi和JSR 277更紧密地结合在一起。

查看英文原文:Are JSR277 and OSGi coming together?

没有回复

回复

深度内容

Flex与JSON及XML的互操作

平台需要互操作性。在这篇文章中,作者仔细研究了Flex和JSON及XML的互操作性。文章也包含了使用E4X库来将XML映射到图表和表格组件的内容,还演示了如何使用as3core库来解码JSON消息。

用Qi4j进行面向组合编程

本文将简要介绍面向组合编程(COP,Composite Oriented Programming)的概念,展示它如何规避OOP存在的一些问题,并重新点燃使用可重用部件组装领域模型(Domain Model)的希望。

系统开发——新学科,新教育

一门新的计算机学科——“系统开发”,强调人性化、匠艺、设计、创意、创新和新事物的涌现,并建议用被称为“bottega”的工作室替代乏善可陈的教室。

图书聚焦:Visual Studio 2008 揭秘

Mike Snell和Lars Powers用他们最近由Sams出版的新书《Visual Studio 2008揭秘》,试图帮助大家提高开发人员的生产力。本文包括一个下载样章——第10章调试。

BPEL为何不是BPM的圣杯?

Pierre Vigneras在本文中讨论了作为标准之一的BPEL所存在的问题。Pierre先给我们大致介绍了一个简单的并行流程,接着讨论了从业者在试图以一个结构化模型为基础表达非结构化流程时遇到的一系列问题。

基于范型的多语言编程

你是否仔细思考过,为什么人们总在讨论“要正确的语言做恰当的事情”?在这篇文章中,Sadek Drobi向你解释了为什么应该在系统内部混合使用多种语言。

采访与书摘《Pro Web 2.0 Application Development with GWT》

Jeff Dwyer就关于他的新书(《Pro Web 2.0 Application Development with GWT》)、GWT1.5以及创建可搜索的Ajax应用谈了一些他的见解。

时刻准备着,迎接IT业的春天

我们需要设身处地地为客户及客户的业务本身着想,与客户同舟共济。更多创新的思路、产品和模式也同样将为IT业带来新的出路。IT业并不需要坐以待毙,在春天到来之后,市场将会更加繁荣!