写点什么

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

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

关注

评论

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

百度研究院的追星逐浪,中国科技的奋发自强

脑极体

Linux网络之 从 C10K 到 DPDK

赖猫

c++ Linux linux编程 C10K DPDK

中美上市软件公司对比中的投资启示

ToB行业头条

区块链轻节点:“身”轻,责任重

华为云开发者联盟

区块链 数据 数据隐私 轻节点

红牛交易所app系统开发

威掂l8929545452

区块链 系统开发 APP开发 红牛交易所

解决Windows2012 R2下安装PostgreSQL报错的问题

PostgreSQLChina

数据库 postgresql 开源

Java Optimizing 读书笔记(一)

绝影-大数据

数据库表数据量大读写缓慢如何优化(2)「查询分离」

我爱娃哈哈😍

数据库 大数据 架构 后端 优化

百度智能小程序打造购票观影一站式体验,影视宣发新玩法助力行业复苏

DT极客

WiFi6 与 5G 的异同分析

石君

5G wifi 28天写作

BI项目失败?看看是不是缺少了这几项闭环!

博文视点Broadview

量化交易系统开发

威掂l8929545452

区块链 系统开发 量化交易系统 交易所

避免短信接口被黑客刷取的方法

香芋味的猫丶

短信防刷 接口安全 短信验证码 短信防轰炸 短信防火墙

Redis 学习笔记 03:字典

架构精进之路

redis 七日更 28天写作

即构微信小程序直播组件是什么?有哪些功能?哪些小程序类目可以使用?

ZEGO即构

在函数计算中到底该不该使用 VPC?

donghui

Serverless

Linux I/O 原理和 Zero-copy 技术全面揭秘

赖猫

c++ Linux linux编程 服务器开发 I/O

Java 程序经验小结:类层次优于标签类

后台技术汇

28天写作

流行的后台管理系统模板总结

老魚

程序员 建站 web全栈

量化策略交易软件开发|量化策略交易系统APP开发

系统开发

高并发架构---TCP

赖猫

TCP 后端 高并发 TCP/IP 服务器开发

Intel首次公布11代酷睿桌面处理器性能:8核i9斩落锐龙12核

科技新消息

OpenYurt v0.3.0 重磅发布:全面提升边缘场景下应用部署效率

阿里巴巴云原生

阿里巴巴 开源 容器 云原生 k8s

开发更便捷 阿里云推出一站式应用研发平台EMAS 2.0

移动研发平台EMAS

阿里云 Serverless AI 低代码 移动研发平台

如何利用策略模式避免冗长的if-else/switch分支判断代码?

李尚智

Java 学习 设计模式

现货合约量化交易系统开发搭建

薇電13242772558

数字货币 策略模式

TypeScript 渐进迁移指南

LeanCloud

JavaScript typescript nodejs

自动驾驶汽车的发展史

anyRTC开发者

人工智能 自动驾驶 AI

Serverless 架构到底要不要服务器?

Serverless Devs

Java 云计算 Serverless 运维 云原生

比特币矿机工作原理

v16629866266

比特币 比特币区块链

开发老人笔记:Git 常用命令清单

华为云开发者联盟

git 代码 bug

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