OSGi为业务所带来的好处

日期: 2010-12-14 作者:Alex Blewitt翻译:张龙 来源:TechTarget中国 英文

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

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

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

  1. 清除

  •   成立由模块化专家所构成的小团队,确保得到管理层的支持
  •   分析现有项目之间的依赖关系,去除不必要或不合适的依赖

  2. 工具与元数据

  •   评估并使用支持OSGi元数据的工具与仓库
  •   为所有项目生成OSGi元数据,以此作为构建过程的一部分(即便没有转向OSGi)

  3. 运行时

  •   根据敏捷与重用性为迁移选择候选者
  •   使用现有库(以此作为粒度级别)创建工作运行时Bundle
  •   在OSGi与非OSGi运行时下进行并发测试

  4. 迭代

  •   一旦迁移到OSGi,那么可能还有更多的候选者来对现有库进行模块化
  •   就共享模块进行报告
  •   单独迁移随后的应用

  成功案例

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

  所有主流的JavaEE应用服务器都运行在OSGi上(GlassFish、WebSphere与JBoss)

  •   SAP将要使用Virgo作为其OSGi运行时
  •   WSO2 Carbon成功运行在了OSGi上
  •   Apache Camel是个ESB(类似于Mule),但它既能运行在OSGi容器内,也能运行在容器外
  •   JBoss正在开发自己的OSGi运行时

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

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

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

翻译

张龙
张龙

相关推荐

  • 案例分析:多阶段元数据一致性分析在北京银行的应用

    还记得苦逼的程序员们在系统上线当天彻夜加班排查上线脚本问题的场景吗?我们给出的办法使用元数据对比分析场景来解决这类问题,那么北京银行科技部门是如何借助元数据管理工具实现IT运营效率的提升。

  • 三个场景玩转元数据应用

    很多企业也意识到了元数据重要性,并购买了元数据系统,但系统如何发挥价值,是需要考虑的问题。元数据到底应该管理哪些数据?分析哪些环节?看似抽象的系统的功能在企业IT、数据建设中有哪些应用场景?

  • 云存储和容量管理

    云存储听上去是如此简单。你只需为你所使用的支付费用,并且在任何时候,都很容易判断你使用的存储量。然而,经验丰富的IT专业人员都清楚,实施一项新技术或方法很少会如此简单。

  • 内存数据网格提供商一头扎进Java

    10年的时间里,应用性能解决方案提供商Alachisoft一直在用NCache(针对N-Tier和网格计算.NET应用的内存计算和数据网格产品)为.NET社区服务。