写点什么

OSGi 为业务所带来的好处

  • 2010-12-13
  • 本文字数:1061 字

    阅读完需:约 3 分钟

近日, Paremus 发表博文谈到了 OSGi 为业务所带来的好处,博文就模块化将成为大型代码基管理与维护的未来方向这一观点进行了讨论。报告还就如何迁移到 OSGi 上给出了建议:首先通过自动化构建生成 OSGi 元数据,然后将应用分别迁移到 OSGi 框架上。

很多人认为迁移到 OSGi 上的代价非常大,但通常这里面包含了模块化本身的代价。无论使用的是 OSGi、Jigsaw 还是其他的模块化架构,要想对大型、复杂、纵横交错的库进行模块化都要付出代价,而这种模块化对于维护者来说并没有立竿见影的好处。然而如果不这么做,系统就会随着时间的推移变得更加复杂、更加的纵横交错,维护代价也会增加。这就好像我们要经常对车进行保养来保持良好的车况一样;如果长年不保养,那么发动机大修的费用就会比所有的保养费还要高,甚至会缩短车的使用寿命。

Paremus 给出了如下的迁移计划:

  1. 清除
  2. 成立由模块化专家所构成的小团队,确保得到管理层的支持
  3. 分析现有项目之间的依赖关系,去除不必要或不合适的依赖
  4. 工具与元数据
  5. 评估并使用支持 OSGi 元数据的工具与仓库
  6. 为所有项目生成 OSGi 元数据,以此作为构建过程的一部分(即便没有转向 OSGi)
  7. 运行时
  8. 根据敏捷与重用性为迁移选择候选者
  9. 使用现有库(以此作为粒度级别)创建工作运行时 Bundle
  10. 在 OSGi 与非 OSGi 运行时下进行并发测试
  11. 迭代
  12. 一旦迁移到 OSGi,那么可能还有更多的候选者来对现有库进行模块化
  13. 就共享模块进行报告
  14. 单独迁移随后的应用

成功案例

虽然有博文报道说 MuleSoft 没有成功迁移到 OSGi ,但几个评论家已经证明了 OSGi 无论对应用服务器还是中间件都是很棒的选择。

就像其他很多框架一样,使用 OSGi 并不意味着一定就会成功,它还经常需要在使用上与代码上进行一些变化以便进行迁移。事实上, OSGi 并非万灵丹——但我们不能仅仅因为它不适合于一个项目就说它也不适合于其他项目。人们可能不会使用 OSGi 实现解析 CSV 并将其加载到数据库中这样的单一用途应用,但他也不可能使用 Spring 或其他框架完成这件事(有些人可能会说这种情况下最好使用 Python 或 Perl 而不是 Java)。

OSGi 还是模块化领域中的一个工具,可用于模块化并在模块之间强制施加边界。随着项目规模的不断扩大,强有力的模块化系统所带来的价值已经超越了实现模块化的代价。

查看英文原文: Business Benefits of OSGi

2010-12-13 11:153846
用户头像

发布了 88 篇内容, 共 273.5 次阅读, 收获喜欢 9 次。

关注

评论

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

全面对比:Apache SeaTunnel VS. DataX、Flink CDC 和 Talend 谁更强?

白鲸开源

开源 数据同步 DataX Apache SeaTunnel Flink CDC

如何基于Docker集群组网模式来部署Kuscia?

隐语SecretFlow

从“看曲线”到“懂问题”:MetricSet Explorer 如何重构指标分析体验

阿里巴巴云原生

阿里云 云原生 可观测

基于AI的质量风险管控

百度Geek说

监控报警 风险管控 可观测系统 线上定位 AI值班人

NeurIPS 2025 | TANDEM:基于双层优化的数据配比学习方法

京东零售技术

下一代 Lakehouse 智能未来新引擎 | Apache Hudi Meetup亚洲站活动回顾

京东零售技术

CAD如何查看编辑图纸文件信息

极客天地

Apache Doris 实时更新全解:从设计原理到最佳实践|Deep Dive

SelectDB

Apache 数据库 Doris

AI 绘画微信小程序系统:一站式变现解决方案

微擎应用市场

维奕网络共享门店小程序系统:实体店业绩倍增新引擎

微擎应用市场

春节吸粉引流神器:“放鞭炮过福年” 微擎应用详细介绍

微擎应用市场

智能合成抠图壁纸相册小程序:新风口工具级应用详解

微擎应用市场

为什么越来越多的头部企业选择 Aloudata Agent?揭示不可替代价值

Aloudata

数据分析 Data ChatBI 智能问数

CAD如何在属性编辑器中修改文字高度

极客天地

Databend 11 月月报:多模态查询智能

Databend

CAD怎么让打印的PDF支持文字检索

极客天地

AI 知识加工平台:你的智能 “知识管家” 是怎么干活的?

上海拔俗

Apache Doris 实时更新全解:从设计原理到最佳实践|Deep Dive

SelectDB

数据仓库 apache doris 数据更新 数据库技术 实时分析

稳居前列,持续攀升!

天翼云开发者社区

云计算 混合云

2025年度AI软件盘点,这40+精选工具值得一试

职场工具箱

效率 AI软件 AI工具 AI 绘图 AI 编程

GSoC 学生太强了!印度开发者为 DolphinScheduler 做出的 OIDC 升级内幕

白鲸开源

开源 开发者 Google Apache DolphinScheduler GSoc

库存越压越多、爆品越抓越难?99%的品牌都输在这 3 个企划陷阱!

第七在线

AI与文化共鸣:超越翻译的本地化艺术

澳鹏Appen

AI翻译

五一缴费平台:便捷高效的生活缴费解决方案

微擎应用市场

JNPF 流程操作权限一键理清,流程列表管理别踩坑!

引迈信息

为了记住20000个英文单词,4000个短语,我干了这件事

Marvin

英语 AI智能体 AI辅助学习

Go后端 vs Go AI应用开发重点关注什么?怎么学?怎么面试?

王中阳Go

Go AI

Apache DolphinScheduler VS. Crontab、Airflow:效率对比实测

白鲸开源

开源 crontab Apache DolphinScheduler airflow 任务调度平台

11月 | 塞讯模拟攻击库更新汇总

塞讯科技

安全验证

CAD为什么打开文件提示只读模式

极客天地

CAD在图纸集中新建图纸,为什么选择模板提示“不包含初始化布局

极客天地

OSGi为业务所带来的好处_Java_Alex Blewitt_InfoQ精选文章