QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

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

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

关注

评论

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

支持M1/M2 SoundSource for Mac v5.6.3直装版 及破解教程

理理

拍立淘API返回值:商品列表与详细信息深度解析

代码忍者

pinduoduo API

国内堡垒机公司有哪些?怎么选择?

行云管家

网络安全 堡垒机 堡垒机公司

游戏推荐业务中基于sentinel的动态限流实践

vivo互联网技术

sentinel 限流 动态限流

Serial for Mac串口调试工具软件

Mac相关知识分享

活动预告 | 10月26日,中国数据库联盟(ACDU)中国行·上海站邀您探讨数据库前沿技术

墨天轮

数据库 开源 国产数据库

F5被IDC MarketScape评为Web应用和API保护领导者

科技热闻

调优:在Java 中字符串重复数据删除性能

哦豁完蛋了

Java’

NIPs 平台:Mint Blockchain 推动 NFT 创新的新平台

NFT Research

NFT\ #Web3

数字活化百年古戏楼,火山引擎打造「虚拟直播间」

新消费日报

【mac/win】Adobe After Effects 2024绿色便携版+破解版 附ae2024激活补丁

理理

可折叠LED广告机的优势及应用场景

Dylan

技术 广告 数字化 LED display LED显示屏

优化和清理 Mac 系统工具MacCleaner Pro for Mac

Mac相关知识分享

长途自驾游太累?火山引擎数据飞轮携手车企持续优化驾车体验

字节跳动数据平台

数据飞轮

Abaqus中的S、U、V、E、CF分别是什么意思?

思茂信息

仿真 abaqus 有限元

面试官:我是如何提问候选人的

老张

招聘 职场成长 面试求职

淘宝商品详情API返回值中的商品推荐理由与卖点

技术冰糖葫芦

API 接口 API 文档 API 测试 API 性能测试

不是大模型,而是业务和技术如何统一指标定义

奇点云

大数据 AI 互联网 软件 IT

Mac 远程管理软件Royal TSX for Mac

Mac相关知识分享

macOS 网络流量监控软件 NetWorker Pro for mac v9.0.1中文版

理理

海南文昌等保测评机构本地有吗?

行云管家

等保 等级保护 等保测评 文昌

Premiere Pro 2024 for Mac中文激活版

Mac相关知识分享

CloudberryDB内核分享:增量物化视图的原理与实现讲解

酷克数据HashData

深度解读GraphRAG:如何通过知识图谱提升 RAG 系统

Zilliz

Milvus 向量数据库 rag graphRAG

观测云产品更新 | AI 智能助手、云账单智能监控、日志错误追踪等

观测云

人工智能 监控 日志

天猫商品评论API:评价内容中的用户情感倾向分析

技术冰糖葫芦

API 接口 API 文档 API 测试 API 性能测试

视频直播技术干货(十二):从入门到放弃,快速学习Android端直播技术

JackJiang

即时通讯;IM;网络编程

RapidClick for mac鼠标自动点击工具

Mac相关知识分享

vector magic for Mac矢量图片转换工具

Mac相关知识分享

京东大模型革命电商搜推技术:挑战、实践与未来趋势

京东零售技术

大模型 LLM

一文看懂——SimSolid的优势

智造软件

仿真 有限元 SimSolid

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