写点什么

采用 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:498988
用户头像

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

关注

评论

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

fastposter v2.11.0 天花板级的海报生成器

物有本末

海报 海报生成器 海报编辑器 海报生成 海报小程序

模块三

GeekMLS

#架构训练营

私有部署V3.8:自建内部应用库和预置应用

明道云

2023-01-05:konradkleine/docker-registry-frontend是registry的web界面工具之一。请问部署在k3s中,yaml如何写?

福大大架构师每日一题

云原生 k8s 福大大

PING命令解析

穿过生命散发芬芳

ping 1月月更

沙龙预告 | 1月11日举办数字化业务安全生产沙龙第2期

信通院IOMM数字化转型团队

数字化转型 IOMM 数字化业务安全生产

ReactDOM.render在react源码中执行之后发生了什么?

flyzz177

React

阿里云网络解决方案架构师任江波:全球一张网,支撑游戏业务高效互联

云布道师

阿里云

【JavaScript】JavaScript(js)简单介绍

No8g攻城狮

JavaScript JavaScript4

我们为什么一定要持有一枚 Smart Royal NFT?

鳄鱼视界

细说react源码中的合成事件

flyzz177

React

2022年中国特色智能工厂领航制造业升级分析报告

易观分析

数字经济 智能工厂

百度百舸·AI 异构计算平台,加速自动驾驶模型迭代

Baidu AICLOUD

自动驾驶 模型训练 异构计算

要做好用户体验,一定要知道这些心理学效应!

产品海豚湾

心理学 产品经理 产品设计 用户体验 交互设计

TextView(文本框)详解

芯动大师

android UI TextView

模块3作业-学生管理系统的架构设计文档

陈实

「架构实战营」

外包学生管理系统架构文档

Geek_e5f2e5

干货!C4D的7个实用插件分享

Finovy Cloud

云渲染 C4D

【深入浅出Sentinel原理及实战】「框架整合专题」Sentinel服务框架对接Dubbo服务框架整合开发指南(4)

码界西柚

dubbo sentinel 1月日更 sentinel dashboard

React源码分析(二)渲染机制

flyzz177

React

我们为什么一定要持有一枚 Smart Royal NFT?

股市老人

论坛预告 | 1月9日举办2023 ICT深度观察政企数字化转型分论坛

信通院IOMM数字化转型团队

数字化转型 IOMM ICT深度观察

架构实战营 - 模块 3- 作业

zealot0317

React源码分析1-jsx转换及React.createElement

flyzz177

React

React源码分析(三):useState,useReducer

flyzz177

React

前端leetcde算法面试套路之双指针

js2030code

JavaScript LeetCode

Triple 协议支持 Java 异常回传的设计与实现

阿里巴巴云原生

阿里云 云原生 dubbo

【异常】Cause: java.sql.SQLException: Invalid value for getInt()

No8g攻城狮

sql Java、 javaWeb

SQL Studio:一款纯Web化SQL开发工具,关键是免安装还免费!

雨果

sql 数据库管理工具 SQL开发

React Context源码是怎么实现的呢

flyzz177

React

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