写点什么

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

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

关注

评论

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

模块二作业

doublechun

「架构实战营」

如何正确使用Spring Cloud Zookeeper,不懂来学,java教程下载网盘

Java 程序员 后端

如何设计一个百万级用户的抽奖系统?,三面蚂蚁核心金融部

Java 程序员 后端

太为难我了,阿里面试了7轮(5年经验,java百度图像识别接口

Java 程序员 后端

头条「2020最新」Spring最易学习教程,百度java面试经验

Java 程序员 后端

如何在Spring Boot应用中优雅的使用Date和LocalDateTime

Java 程序员 后端

如何阅读一本书-读书笔记,java二到三年经验面试题

Java 程序员 后端

大学毕业年的找工作和学习总结,java中级开发工程师面试题

Java 程序员 后端

太全了吧!阿里面试官纯手打:金三银四跳槽必会Java核心知识点笔记整理

Java 程序员 后端

如何理解互斥锁、条件锁、读写锁以及自旋锁(1),mysql入门到精通电子书

Java 程序员 后端

太狠了,Spring全家桶笔记,一站式通关全攻略,已入职某厂涨薪18K

Java 程序员 后端

如何使用Spring Cloud Consul的其他配置和发现功能,不会来学

Java 程序员 后端

如何保证Redis与数据库的双写一致性?,十分钟带你看懂Netty如何实现C-S

Java 程序员 后端

如何在今年难找工作的大环境下成功入职阿里?Java架构师面试高频300题:集合

Java 程序员 后端

天真,居然还有人认为java的参数传递方式是引用传递(1)

Java 程序员 后端

天真,居然还有人认为java的参数传递方式是引用传递,互联网java工程师面试突击训练网盘

Java 程序员 后端

架构实战营 - 毕业总结

雪中亮

架构实战营 #架构实战营

如何保证高可用?搞定三种集群模式,Redis还不是手到擒来

Java 程序员 后端

如何在分布式系统中正确的使用缓存?别给你的项目引入定时炸弹!

Java 程序员 后端

太厉害了,终于有人把TCP-IP协议整合成864页学习笔记了

Java 程序员 后端

如何快速成长为技术大牛?阿里资深技术专家的总结亮了!

Java 程序员 后端

如何让阿三 Windows 10、11 的恢复分区(Recovery Partition

Java 程序员 后端

太狠了!阿里技术官熬夜半年肝出来的Spring Boot巅峰之作,爱了

Java 程序员 后端

太难了,救救孩子吧,到现在还搞不懂TCP的三次握手四次挥手

Java 程序员 后端

天才第一步!Java架构速成笔记必备精品成就年薪百万,掌门一对一java面试流程

Java 程序员 后端

太强了!阿里大神亲码“SpringCloud核心手册,2021Java常见笔试题

Java 程序员 后端

太牛了,Github上标星30K+的SpringBoot实战电商项目mall

Java 程序员 后端

如何让自己像打王者荣耀一样发了疯、拼了命、石乐志的学习

Java 程序员 后端

大四实习生”都四面成功拿到字节跳动Offer了,你还有什么理由去摸鱼

Java 程序员 后端

天天阿里,不如先吃透阿里技术官私藏的分布式笔记,最少能到P6

Java 程序员 后端

太难了,面试官不讲武德!来骗来偷袭,分层架构图案例

Java 程序员 后端

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