NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

采用 OSGi 框架开发项目的十个问题

  • 2010-03-11
  • 本文字数:1163 字

    阅读完需:约 4 分钟

近期,InfoQ 针对 Java 模块化(基于 OSGi)这一热点技术问题连续做了四篇深度报道:

其中对 OSGi 的基本概念和现状以及模块化技术细节做了详细描述:

OSGi 是 Java 领域里无可辩驳的最成熟的模块系统,它与 Java 几乎是如影相随,最早出现于 JSR 8 ,但是最新规范是 JSR 291 。 OSGi 在 JAR 的 MANIFEST.MF 文件中定义了额外的元数据,用来指明每个包所要求的依赖。这就让模块能够(在运行时)检查其依赖是否满足要求, 另外,可以让每个模块有自己的私有 classpath(因为每个模块都有一个 ClassLoader)。这可以让 dependency hell 尽早被发现,但是不能完全避免。和 JDBC 一样,OSGi 也是规范(目前是 4.2 版),有多个开源(及商业)实现。因为模块不需要依赖任何 OSGi 的特定代码,许多开源类库现在都将其元信息嵌入到 manifest 中,以便 OSGi 运行时使用。有些程序包没有这么做,也可以用 bnd 这样的工具,它可以处理一个已有的 JAR 文件并为其产生合适的默认元信息。自 2004 年 Eclipse 3.0 从专有 plugin 系统切换到 OSGi 之后,许多其他专有内核系统(JBoss、WebSphere、Weblogic)也都随之将其运行时转向基于 OSGi 内核。

不过,Java 社区领袖 Adam Bien 最近在其博客中认为,从技术角度讲,OSGi 的确是实现模块化的可行办法,但 OSGi 的主要挑战不是技术,而是模块和 bundle 的管理。他建议在决定采用 OSGi 框架开发项目之前,考虑以下问题:

  1. 针对模块(bundle),采取何种版本控制方案?大、小版本如何定义?
  2. 采用何种软件配置管理策略?允许开放和维护模块所有版本的分支吗?预计要维护多少个分支?通过 SVN 吗?
  3. 在生产环境中,同时存在多少不同版本的模块?
  4. 针对模块和模块组合,如何进行测试?每一个版本都会显著增加复杂度。
  5. 采用何种发布管理策略?提供客户专属的模块组合吗?缺陷修补 / 补丁策略是什么?
  6. 需要在系统运行中替换模块吗?如何处理正在进行的事务?
  7. 对于 Eclipse RCP 应用,是否应该开放插件给最终用户?
  8. 采用何种软件分发系统?很多公司已经有了一套软件分发系统。应用和 JVM 经常打包到一个二进制文件中整体安装。增量更新几乎是不可能的。
  9. 模块之间如何交互?只通过 Java 接口吗?如果是,那么 JPA 实体的直接关联如何处理?
  10. 是否采用 Maven 描述模块和 OSGi?Maven 模块版本会在 OSGi bundle 版本中得到体现吗?

Adam Bien 认为,在深入思考这十个问题之后,OSGi 可能就不再是项目的最佳选择。

读者朋友是否同意 Adam Bien 的观点,针对他的十个问题,有何看法?在实际开发中又是如何解决的?欢迎踊跃发表意见。

即将召开的 QCon 北京2010 大会设有“设计优良的架构”专题,关心 OSGi 架构应用的读者可能会对其中的“设计可扩展的架构”、“架构与最佳实践及创新的关系”等演讲感兴趣,敬请关注。

2010-03-11 07:498715
用户头像

发布了 501 篇内容, 共 248.5 次阅读, 收获喜欢 57 次。

关注

评论

发布
暂无评论
发现更多内容

「Macos排版神器」Affinity Publisher for Mac中文直装版

彩云

Affinity Publisher

DAPP代币燃烧铸币质押挖矿系统开发(源码搭建)

l8l259l3365

Amazon EC2的出现,是时代的选择了它,还是它选择了时代

淼.

ClickCharts for Mac(轻量级思维导图软件)v8.67激活版

影影绰绰一往直前

专业核磁数据处理软件MestReNova 14破解版

iMac小白

Coherence X for Mac「网站转换为Mac应用」

彩云

Coherence X

jdk8 Stream流中将集合转成map,重复key处理,统计最大值,获取某个属性集合等10种最常用方法

javaNice

Java stream

基于FX构建大型Golang应用

俞凡

golang 架构

Rhino 8 for Mac「犀牛 3D建模工具」

繁星

犀牛3D建模软件 3d建模 Rhino 8

menubarx for mac(强大的菜单栏浏览器工具)v1.6.5直装版

影影绰绰一往直前

MacOS数据库:Navicat Premium 15 for Mac中文破解版

影影绰绰一往直前

SQL 的 AND、OR 和 NOT 运算符:条件筛选的高级用法

小万哥

MySQL sql 程序员 后端 开发

文心一言 VS 讯飞星火 VS chatgpt (138)-- 算法导论11.4 2题

福大大架构师每日一题

福大大架构师每日一题

Mate Translate for Mac(翻译软件) v8.1.3激活特别版

mac

翻译软件 苹果mac Windows软件 Mate Translate

亚马逊Lightsail:云服务新篇章,轻松开启您的数字未来

熬夜磕代码、

亚马逊云 AWS Lightsail

iTubeGo for Mac(网页视频下载软件)完美激活版

mac

视频下载工具 苹果mac Windows软件 iTubeGo

ON1 Photo RAW 2024 for Mac(照片编辑器)中文版

影影绰绰一往直前

Coherence X for mac(将网站转变为Mac应用程序)v4.5.2激活版

影影绰绰一往直前

目前为止BRC-20是炒作还是泡沫

币离海

BRC-20 铭文

Charles for Mac中文破解版下载

影影绰绰一往直前

Topaz DeNoise AI for Mac(图片降噪软件) v3.7.2完美激活版

mac

苹果mac Windows软件 图片降噪软件 Topaz DeNoise AI

iShowU Studio 2 for mac(屏幕录像编辑工具)v2.3.12注册激活版

影影绰绰一往直前

iShowU Studio 2 for Mac(屏幕录制编辑工具) 2.3.12永久激活版

mac

苹果mac Windows软件 iShowU Studio 2 屏幕录像工具

Jenkins 打包shell出现gradle命令不存在,jvm内存溢出

javaNice

Java jenkins

Redis缓存雪崩、击穿、穿透解释及解决方法,缓存预热,布隆过滤器 ,互斥锁

javaNice

Java redis

Kubernetes成本优化

俞凡

Kubernetes

SQL INSERT INTO 语句详解:插入新记录、多行插入和自增字段

小万哥

MySQL 数据库 sql 程序员 后端开发

JProfiler 14 序列号激活 附 完整安装教程

繁星

JAVA开发 JProfiler 14

Rocket Typist pro for mac(文本快速输入工具)v3.0.8激活版

影影绰绰一往直前

采用OSGi框架开发项目的十个问题_Java_崔康_InfoQ精选文章