实施SOA可能带来的主要优势有5点:
一,SOA可通过互联网服务器发布,从而突破企业内网的限制,实现与供应链上下游伙伴业务的紧密结合。通过SOA架构,企业可以与其业务伙伴直接建立新渠道,建立新伙伴的成本得以降低。
二,SOA与平台无关,减少了业务应用实现的限制。要将企业的业务伙伴整合到企业的“大”业务系统中,对其业务伙伴具体采用什么技术没有限制。
三,SOA具有低耦合性特点,增加和减少业务伙伴对整个业务系统的影响较低。在企业与各业务伙伴关系不断发生变化的情况下,节省的费用会越来越多。
四,SOA具有可按模块分阶段进行实施的优势。可以成功一步再做下一步,将实施对企业的冲击减少到最小。
五,SOA的实施可能并不具有成本显著性。这要分三种情况加以讨论:
当企业从零开始构建业务系统时,采用SOA架构与不采用SOA架构成本可看做是相同的。
当企业业务发展或发生企业重组等变化而原有系统不能满足需要,而需要重构业务系统时,采用SOA架构与不采用SOA架构成本可看做是相同的。
当企业业务发生缓慢变化并可预见到将来需要重构业务系统时,由于可以按模块分阶段逐步实施SOA以适应变化的需要,这样企业不需一下投入一大笔经费进行系统改造,而是根据企业业务发展情况和资金情况逐步投入,缓解了信息投入的压力。
但是,SOA并不是天上掉下来的馅饼,企业要实施SOA必须具备一定的条件,否则很难实施成功。SOA会给企业信息设施和管理带来以下4方面的挑战:
一,人才的匮乏
SOA是近年来才出现的新概念,懂得和深入了解SOA的人不多,SOA专家更是寥寥无几。企业需要的SOA人才,要有SOA架构师,以及熟悉SOA的开发技术人员,同时各SOA应用部门的关键人员,也需要理解SOA的内涵以实现与业务的结合。
二,开发平台和开发工具的选择
实施SOA对开发平台和开发工具没有特别要求,这给企业对平台和工具的选择造成了盲目性。对于不具备丰富实施经验的企业,很有可能选择到最终不适合自身发展需要的平台和工具。这要求企业既要对各开发平台和工具有深刻的了解,又要对自身业务及发展方向有深刻的了解。
对于SOA开发工具来说,总的要求是能够“多快好省”的满足企业实施SOA的需要。虽然一些企业已经推出了SOA开发工具,但还未看到其中有相当成熟的“王者”出现。
三,技术环境的限制
SOA可通过互联网送达到每个角落,这同时也要求了强大的送达能力。在现实网络环境中,送达能力由于带宽的限制往往是达不到的。
松耦合往往提高调试的难度,这是笔者的观点。最紧的耦合就是所有代码都在一个过程中完成,一旦发生问题可立即追踪的问题点。采用面向对象的开发后,尤其是程序跨进程后,耦合度大为减低,但程序发生错误后要花更高的代价才能找到问题点。当采用Remoting、Web服务及分布式处理后,耦合性进一步降低,但调试难度也越来越高。实施SOA也会面临这个问题,众多的分布式服务,到底是哪一个出了问题,很难确认。问题往往在若干步后,经过了若干服务才体现出来,要最终到问题的源头非常困难。
网络的不稳定性会对SOA系统造成影响。随着时间的增加及数据量的增加,影响程度可能会逐步加大并达到很严重的程度。
四,安全性的影响
松耦合可能会给攻击者找到漏洞的机会。当整个SOA系统节点众多业务复杂时尤其会给攻击造成可乘之机。
数据安全性也难以得到保证,某些关键性数据可能会在非预期的节点流出。
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
作者
相关推荐
-
预测2015:新模式、新市场、新安全
IT行业在过去一年里继续深刻影响着各行各业的发展进程。IT正在从一个单纯的支持部门“进化”到企业的创新部门,随着新技术的不断发展,IT还会出现哪些不同?站在2014年年末这个时间节点,我们不妨来跟随瞻博网络的预测报告,大胆畅想一下2015年会有哪些新的变化。
-
MetaFabric:为解决云端迁移难题而生
过去,各式各样刻板的盒子和线缆会将企业束缚于专有系统的牢笼之中。这样的日子将一去不复返。而现在,通过一个基于云的网络实现敏捷的应用托管、内容协作以及企业流动性。
-
IT如何应对物联网挑战?
技术总是不断的改变IT进程,转型始终是IT的主旋律。技术固然变化莫测,但对IT以及CIO来讲,却也有一条亘古不变的原则——让IT成为企业的增长动力,从这个角度来看,物联网不是什么洪水猛兽,而是一个非常好的机遇。
-
见证思科中国二十年 我和思科的点滴网事:工程师不但要技术过硬
思科的工程师不但要技术过硬,还要知识面宽泛,更要善于学习,以随时准备进入新的领域。