RSS订阅
RSS订阅TT SOA

从现存的应用来构建Web Services

2008-4-28  选择字号:  | |
打印本文章

导读:从现存的应用来构建Web Services,IBM,Microsoft,Sun,HP,Oracle和BEA就是其中的参与者,他们或声称是他们创造了Web services或说他们可以提供最佳的Web services服务。

关键词:Web Services IBM Microsoft Sun HP Oracle BEA

正在加载数据...

  当一个新的想法成为真的一件好事的时候将会发生什么了?人们争相宣称是他们提出了这个想法。而且另外一群人则想占有这想法,并为它增加或修改点什么,这样他们可以说是他们让它更美好。

  可能这就是Web services的处境。IBM, Microsoft, Sun, HP, Oracle 和 BEA就是其中的参与者,他们或声称是他们创造了Web services或说他们可以提供最佳的Web services服务。

  为什么所有的这些卖主都欲竟相领导这个领域了?答案是: 钱 。Web services是个伟大的观念,它允许应用软件能被构建集成到一起,并基于应用来部署,这些应用构建于块,块的接口或API遵循自我证明标准。这个观念将可能革新人们对软件应用是如何开发和交付的观念。

  根据Gartner所说,Web services市场在下个三年将预期增长到280亿美圆,但Web services并不只是成为潮流的下一个好想法,也不只是关于软件将如何开发的。它也将有关于软件是如何被售卖,并且更重要的是我们将如何购买和为之付费。实际上,很合理的想到微软正将它整个软件技术移向基于.net的Web services模型的一个主要原因正是它给予了公司为应用软件而完全改变它的商业模型的机会。

  定义Web services 在Web services背后的想法是软件解决方案能被交付于远程web上的离散的services,用通用的方式理解每个service作什么和用它集成什么。为了使这点实现,该行业已经建立了一些标准如:统一描述、发现和集成(UDDI),Web services定义语言(WSDL),和简单对象访问协议(SOAP)。这些标准让一个应用开发者找到一个提供所需的功能Web service和理解这个Web service是如何运转的,且集成这个Web service,该Web service有效地使用基于标准接口语言的远程调用。

  然而,用宿主在远程Web上的功能性模块(可能是匿名的)来集合成新应用软件观念仍旧离现实还很远。在这些幻想成为现实之前有许多问题要克服。下面是三个主要障碍:

  至今无任何services — 这可能有点夸大其词,但它准确的道出了我们距拥有丰富的可用的预构造的功能应用services将有多年之远。行业正创建许多我们能用来开发新的Web services的工具,并且IBM的Web services工具就是帮助我们开发新Web services的积极例子。

  仍无一个商业模型 — 没有谁真地作出它的商业模型。就像三年前ASP观念一样,Web services是一个好想法,但你该如何用它来赚钱了?

  共享的动机可能不充分 — Web services之后的驱动力量就是为了团体共享他们的知识产权。不幸的是,软件的内部功能被看作是私有服务。故在认识到他们在市场上卖的是内部的部分功能而不是完整的解决方案时,软件开发公司将要很大地转变他们的观念。

  慌乱为什么存在? 那么如果Web services尚且处在幼年阶段,我们为什么能听到如此多有关它的说法了?因为它是有利的!现在Web services的观念已经在使用中了,但不是作为应用功能之源的方式,而是把应用集成到一起并且可在企业或贸易合作伙伴组织间建立新的应用的高产的可升级的方式。

  两个因素驱动开发企业应用集成(EAI):

  可扩展性/性能

  业务流粒度控制在集成系统内

  EAI的开发已经从批更新过程转向在事物级别的应用集成,然后到使用高级别消息的应用到应用的集成。下一需求将是要获得更大的可扩展性和在业务功能级别的集成应用的粒度控制,而Web services架构就为之提供了方法。

  今天大部分使用Web services架构的项目是在企业内或贸易合作伙伴之间构建应用服务集成的EAI项目。公司正意识到为了将来应用软件的发展,如果他们想转移到Web services架构上,他们需要一个方法将存在企业内以行的软件功能转为新的Web services。这种选择(将以有的黄金功能模块重写为新的Web services)是低耗而费时的。

  想象下这样一个场景:一个企业提供它的核心商业应用软件的所有可行逻辑以作为可重用的Web services。那样,作为新应用软件开发进行的需要,开发者可立即调用丰富的可立即用的Web services而组合成为新的应用。他们可注重于努力开发创建新的商业过程服务,该服务然后能被将来开发可利用。

  许多公司认识到组件化的遗留应用商业准则是个很有价值的投资。Web services提供了架构和一组成为这些项目结构的标准。

  功能点分析 为了度量程序员的生产力和软件开发的投资,许多组织使用了功能点分析。使用功能点为单位的好处是注重于度量各自应用功能点而不是他们的编程语言和独立的技术。平均每个程序员一年全职工作可开发270个新应用功能点。

  大部分的核心应用由上万个功能点组成。开发一个新的应用功能点要耗费$550到$2,000,甚至更多,而存在的核心系统可能将要有数百万美圆的投资,所以一个被迫的选择是重用方法学,让你在的开发投资上继续收获回报并且减少花费和新项目开发的风险。

  将你的核心应用逻辑公布为可重用的Web services而获得投资收益,为了将来把你的公司转型为灵活的、高综合的科技领域。另外,这个重用过程将有助于在你的IT公司中拆卸知识岛屿并且帮助您优化新项目资源。你的遗留应用开发资源将被JAVA或.NET程序员吸收利用。

  通向成功的三步 公布以存的应用为Web services的过程包括三个步骤:

  知道你拥有什么 — 许多战略应用软件已开发了数十年之久,被修改了再修改,所以文档是过时的或根本不存在。经常,这最重要的应用成为了未知领域,如果你贸然使用,将会有很多麻烦。可能会显示消息:“如果它不停下来,就不要修理它。”只有“远古的高贵的”COBOL程序员才能涉险这个领域。不幸的是,当那些COBOL程序员离去或退休许多公司只能看着COBOL编程技巧消失,而又很难替代这些个别的能力和知识。

  所以,如果我们想将遗留应用转为动态的、易使用的和易理解的Web services,我们必须学会遗留的应用软件是什么?它们作些什么?它们其中的商业准则在哪里?你可以使用应用理解工具做到这点。不要将适合的应用理解工具误解为用来Y2K修正项目的代码限制工具。这个你所需要的工具必须提供你应用软件的整体上的和语义上的理解。当提供内部应用流、事物处理和业务逻辑时,它必须能理解整个应用软件的上下文,包括程序代码、数据库和工作控制环境。

  挖出真金 — 一旦你理解了你的核心系统知道了商业准则在哪里,那么下一步就是孤立它们以用来重用为Web services。这个过程可被划分成非干预的和可干预的方式。有时,分离与一个特殊业务功能相关的代码元素可能很难。较少干预方式可能更有意义,这种方法将可公布为Web services的业务过程限制于功能性,该功能性能通过屏幕擦写或从数据库创建服务来访问。

  简单屏幕擦写可能并不能提供基于service的架构,该架构需要公布实际的业务功能为Web services。任何基于通过屏幕I/O接口来公布业务逻辑的非干预方式必须提供这一级别粒度用来公布每个屏幕接口为一个应用services集合,或任何屏幕的团体是单应用service。基于接口的屏幕提供优化可扩展性也是基本的。如果对每个过程基于屏幕服务的练习,架构是基于对等网络的关系的话,那么它不可能是充分的解决方案。

  建立数据库services可能也将是个挑战,因为许多商业系统是基于COBOL文件系统的或其它非关系数据的。在基于架构的services-上的纯数据的访问意味着这些数据通过一些形式访问语言(如SQL)而暴露。大部分的COBOL数据库不支持本地SQL访问。然而,市场上有中间件产品能提供非SQL适应数据的开放存取,那么这些中间件工具就需要集成到Web services结构和标准中。

  更完全的和最具战略性的解决方案是公布程序逻辑为可重用的services,这需要采取干预方式——进入到代码中去。如果你对应用理解投入足够的投资,那么这就不是那么难了。而且,可获得的工具能帮助你从以存在程序中隔离和抽取数据,然后将这些数据打包而作为离散的service使用。

  创建Web services — 已经理解了你的应用软件后,然后发现和收获你想重用为Web services的商业准则,你现在需要调节你的产品以使你能公布COBOL,C或其它的遗留程序为SOAP上的Web services。

  一种可选的适配方法是自动将分离的数据翻译成Java或C#,意识到这点,虽然它听起来具有吸引力,但自动转化遗留语言代码为适应的Web services代码,它是具有很多缺陷的。你几乎不能将清楚的转化用新的语言来完成。通常,在新的目标语言中效法原始代码结果是种错误的架构。你获得其半成结果,不管如何,你的程序员要理解或继续工作。

  如果适配方法将商业逻辑留在现有语言中,一个好的适配环境将可允许你采用新语言写的services与遗留的services混合。这个演变方式让你逐渐转换根本的技术,而避免重开发的灾难性危险。

  为了正确的实现这三步,你将需要软件工具和中间件(见图1)来帮助你完成工作。

  图1 为转化以存在的应用商业准则为Web services的中间件栈

  结论 上述过程描述了从现有的核心商业应用来创建Web services的有效方法。为了它的益处,只有勇敢的公司才能着手大的项目将他们以存在的应用软件转化为Web services仓库。商业需求和驱动才能领导这些项目。

  应用理解 — 第一步必须完全地理解和文档化你现有的系统,你的IT公司就要完成第二和第三步——识别出应用集成和新应用组合的需要,然后完成从以存在的应用去创建可重用的Web services而需履行的步骤。经常,重要的新的应用能使用相对少的数量的遗留商业准则而被构建或集成为Web services而公布。通过这种项目接项目的方式,交付你公司切实利益同时,你可以完全地转换为Web services的架构。尽量应用这一伟大想法吧,Web services明天是有保障的。

来源:RDXX    
目前,SOA(面向服务架构)大潮正在席卷着整个世界,而且势不可挡。作为一种集成企业应用的方法论,SOA具备灵活性、标准性、重用性强和成本低等优点……
还记得在20世纪90年代初,人们开始初步尝试使用互联网,不过在那个时候使用互联网绝对没有像今天这么方便。当时,为了帮助人们更好地应用互联网,IBM开始了在这方面的……
期我们回顾了甲骨文和SUN在2008年的收购经历及笔者对收购事件的解读。本期我们将继续这一话题,而我们所点评的软件厂商包括微软、雅虎、IBM、Novell和BMC……
在和客户以及合作伙伴交流的过程中,我们经常会被问到IBM的三款ESB产品的差别以及如何选择合适的ESB产品。在这篇文章中,我们分成两个部分介绍了ESB以……
在本文的第1部分中,我们介绍了企业级应用的发展过程,ESB的特性以及IBM的三款ESB产品各自的区别和侧重。在本文中,为了更进一步了解三款产品在开发和部署方面的差异……
虚拟化和SOA之间是一种间接的、相辅相成的关系。也许在IT及业务转型中,两者的结合使用会发挥最大的优势。虚拟化有助于更快地显示部署基础设施的投资回报率(ROI)。
云计算的概念越来越流行,Amazon、Google和IBM是第一批将云计算引入公众视线的公司。云计算就是新的Web2.0,一种既有技术上的市场绽放。
安全对于许多的IT部门来说都是一个重要的问题之一,但是SOA安全问题完全是在另一个新的纬度上了。对于SOA为一个机构所带来的许多的好处,例如具有在许多不同的提供者和供应商的情况下混合和匹配服务。
最新更新
专家答疑
技巧
Ron Schmelzer,Jason Bloomberg
你认为通过遵循IT组织步骤可以演变为SOA吗?ZapThink公司明确SOA实行肯定是一个挑战——也不应被视为这一倡议应得到执行的一个步骤就是整个企业的基础……
Dana Gardner
您能解释什么是“私有云”吗,能否举例说明?这是供应商需要建立的基础吗?作为托管服务供应商和服务供应商寻求最有效和最强大的基础设施,作为他们的“云”支持能力……
Andrew Pollack
我们正在寻找一种从主机选择SOAP服务器的请求。我们希望制造一个远程程序呼叫(RPC)从CICS程序的SOAP服务器,其中进程请求,使错误或成功后的反应……