写点什么

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

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

关注

评论

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

如何让全彩LED显示屏更加节能环保

Dylan

LED LED显示屏

居家办公那些事|社区征文

CrazyGeek1996

居家办公 社区征文 7月月更

【Python技能树共建】python urllib 模块

梦想橡皮擦

Python 7月月更

Spring Cloud源码分析之Eureka篇第二章:注册中心启动类上的注解EnableEurekaServer

程序员欣宸

Java spring SpringCloud 7月月更

第五届 Polkadot Hackathon 创业大赛全程回顾,获胜项目揭秘!

One Block Community

区块链 科技

基于OpenHarmony的智能金属探测器

OpenHarmony开发者

OpenHarmony

IPv6与IPv4的区别 网信办等三部推进IPv6规模部署

郑州埃文科技

ipv6 ipv4 IP地址

龙蜥社区第九次运营委员会会议顺利召开

OpenAnolis小助手

阿里云 开源 龙蜥社区 运营委员会 运营代表

7 大主题、9 位技术大咖!龙蜥大讲堂7月硬核直播预告抢先看,今天见

OpenAnolis小助手

云原生 技术干货 龙蜥大讲堂 7 月预告 精美周边

《信息系统项目管理师》备考笔记---信息化知识

IT蜗壳-Tango

软考 7月月更 信息系统项目管理师

leetcode 10. Regular Expression Matching 正则表达式匹配 (困难)

okokabcd

LeetCode 动态规划 数据结构与算法

什么叫做信息安全?包含哪些内容?与网络安全有什么区别?

行云管家

网络安全 信息安全 数据安全

【云资源】云资源安全管理用什么软件好?为什么?

行云管家

云计算 安全管理 云资源

TDengine 社区问题双周精选 | 第三期

TDengine

数据库 tdengine 时序数据库

谈谈对Flink框架中容错机制及状态的一致性的理解

百思不得小赵

flink 容错机制 状态 7月月更

spark调优(一):从hql转向代码

怀瑾握瑜的嘉与嘉

spark 7月月更

不要再说微服务可以解决一切问题了!

博文视点Broadview

分类TAB商品流多目标排序模型的演进

得物技术

算法 得物

NFT 交易市场主要使用 ETH 本位进行交易的局面是如何形成的?

NFT Research

区块链 NFT

激动人心!2022开放原子全球开源峰会报名火热开启!

kk-OSC

开源 开发原子全球开源峰会 开源峰会

《2022年中国银行业RPA供应商实力矩阵分析》研究报告正式启动

易观分析

银行用户

C++|TCP客户端中发送文件

中国好公民st

c++ TCP通信 7月月更

程序员内卷和保持行业竞争力

沃德

程序员 7月月更

如何将 DevSecOps 引入企业?

SEAL安全

DevOps DevSecOps DevSecOps和敏捷

百问百答第45期:应用性能探针监测原理-node JS 探针

博睿数据

自动化 博睿数据 性能检测 百问百答 智能运维AIOps

OpenHarmony应用开发之Navigation组件详解

坚果

HarmonyOS OpenHarmony 7月月更

小红书自研KV存储架构如何实现万亿量级存储与跨云多活

小红书技术REDtech

存储 分布式KV 跨云多活

购买小间距LED显示屏的三个建议

Dylan

LED显示屏

ACID事务理论

源字节1号

软件开发

超高效!Swagger-Yapi的秘密

百度Geek说

后端 swagger

手把手带你入门Apache伪静态的配置

迷彩

Apache SEO伪静态 7月月更

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