登录注册
请使用微信扫一扫
关注公众号完成登录
2008-08-04 18:38来源:希赛关键词:SOA收藏点赞
我要投稿
面向服务的体系结构(Service-OrientedArchitecture,SOA)强调企业内不同系统间的松散耦合。服务接口结构在SOA中是最重要的,因为设计糟糕的服务接口对需要使用这些接口的所有应用程序都会造成负面影响。设计良好的服务接口能够加速项目计划的执行,从而提高您的SOA解决方案对业务需求的响应能力。本文是本系列的第1部分,重点讨论服务接口设计的最佳实践,包括有关开发方法、服务粒度以及操作签名方面的概述。本系列的后续文章将讨论设计Web服务描述语言(WebServicesDescriptionLanguage,WSDL)文档结构以及错误处理方面的最佳实践。
引言
面向服务的体系结构(Service-OrientedArchitecture,SOA)正快速成为很多企业中的主要体系结构样式。构建SOA解决方案的主要目的是通过松散耦合其系统来对企业进行武装,从而能更好地响应业务需求。在SOA解决方案内设计Web服务的主要目标之一是支持快速构造业务流程。您还希望加速企业内以及与外部业务合作伙伴的应用程序集成。
在实现SOA解决方案的上下文中,服务接口的结构非常重要。设计糟糕的服务接口可能会极大地导致使用此接口的很多服务使用者应用程序的开发过程变得非常复杂。从业务角度而言,设计糟糕的服务接口可能使得业务流程的开发和优化变得复杂。相反,设计良好的服务接口可以加速开发计划的执行,并对业务级别的灵活性起到促进作用。
Web服务从本质上就非常适合用于构造SOA解决方案。Web服务领域的很多现有和未来的行业标准可确保互操作性,此类标准包括SOAP、JavaAPIforXML-basedRPC(JAX-RPC)、WSDL和WS-*规范等等。各种流行的开发环境(如IBM®Rational®ApplicationDeveloper和IBMWebSphere®IntegrationDeveloper)中均包含了基于标准的工具,从而能够加速SOA项目的进行。
本文的重点是服务接口设计抽象层面的东西:
设计与开发方法
服务粒度
操作签名
开发方法
基于XML和Web服务的编程模型和开发工具定义了三种构建Web服务的方法:
自底向上
各种先进的集成开发环境(IntegratedDevelopmentEnvironment,IDE)提供了用于从现有代码(如Java™或COBOL)创建Web服务实现的工具。使用此方法时,开发人员通常将选择现有的JavaBean或EJB组件,并调用向导来生成WSDL文件,以用于将Bean或EJB作为Web服务调用。
自顶向下
使用此方法时,开发人员将首先使用WSDL和XML模式(XMLSchema,XSD)构造定义Web服务接口,然后为服务生成框架实现代码。接下来,开发人员将完成框架服务实现。大多数先进的IDE(如RationalApplicationDeveloperV6和WebSphereIntegrationDeveloperV6)都为此方法提供工具支持。
中间相遇
此方法对前面两个方法进行了结合。开发人员首先使用WSDL和XSD定义服务接口,并为服务生成框架实现。如果有必要,开发人员还可以使用自底向上技术来通过方便的应用程序编程接口(ApplicationProgrammingInterface,API)公开现有代码。然后开发人员将编写在新设计的接口和旧接口之间进行转换的代码。
很多熟练的Java开发人员喜欢使用自底向上技术来加速SOA项目中的Web服务开发。他们将首先用Java开发新服务的实现,然后将使用强大的代码生成向导来为这些服务创建WSDL接口。尽管此方法可以加速各个服务的实现,但这对整个SOA项目通常都意味着问题。
之所以出现问题,是因为自底向上生成经常会得到无法重用的类型定义以及多个定义为表示语义等效信息的类型。
最佳实践:使用自顶向下和中间相遇开发方法,而不使用自底向上技术。使用XSD和WSDL设计您的服务接口,然后生成框架Java代码。
当存在现有遗留代码(例如JavaBeans、EJB、COBOL等)时,就适合使用自底向上开发方法。采用此方法时,应该仔细地复查现有类的接口,然后再生成WSDL接口。如果Java接口仅包含任何以下内容,则可以将其视为弱类型:
作为方法的参数或返回类型使用的java.lang.Object
作为方法的参数或返回类型使用的集合类(例如java.util.Vector)(JAX-RPC约束)
应该考虑对遗留代码进行重构,以确保接口为强类型;或构建中介,以使用强类型接口包装弱类型接口。
Java与WSDL的比较
可以使用Java或WSDL描述您的服务接口。Web服务相关的规范(如SOAP、JAX-RPC和JAX-B)定义了映射,以说明采用Java定义的类型如何映射到WSDL/XSD中以及如何进行反向映射。
最佳实践:使用WSDL和XSD(而不是Java)描述服务接口。服务接口定义是一种WSDL端口类型。
XML模式规范定义范围比Java更广的用于描述消息结构的构造。其中包括各个选择、限制的派生、Annotation及其他。因此,与采用其他方式相比,使用WSDL和XSD定义接口并生成框架Java代码的方式更好。
WSDL和XSD一起形成了与技术无关的可供SOA实现使用的接口定义语言。除了Java之外,WSDL/XSD接口定义可以用于生成采用很多语言(例如COBOL和C )的框架实现。
特别声明:北极星转载其他网站内容,出于传递更多信息而非盈利之目的,同时并不代表赞成其观点或证实其描述,内容仅供参考。版权归原作者所有,若有侵权,请联系我们删除。
凡来源注明北极星*网的内容为北极星原创,转载需获授权。
近日,广东省质量技术监督局召开了国家质检总局科技计划项目基于SOA的电能质量分析仪自动校准系统(项目编号:2013QK258)结题验收会。专家组认为该项目符合验收要求,同意通过验收。电能质量分析仪是一种用于监测和记录电网供电质量的计量仪器,广泛应用于电力生产、电力送配、用电等领域。电能质量分
众多重点领域在使用国外应用软件。我国的能源、电力、石化电信、金融等众多重点领域都在广泛使用诸如SAP、Oracle等国外的管理软件产品。这些应用软件的底层代码均由国外公司负责开发维护,无法做到自主可控。而应用软件往往涉及企业经营的核心机密,财务信息、产品信息等存在一定的安全隐患。信息安全形势严峻要求应用软件自主可控。棱镜门、RSA算法等诸多信息安全问题相继暴露,国外的基础软、硬件产品的安全性被广泛质疑。我国的应用软件的国产化程度相对于基础软件来说要高得多,比如在ERP领域国产软件市场的份额超过70%,但是在很多大型企业项目的竞争上相对于国外产品经常处于
作为一个SOA最佳实践的长期支持者以及凯捷咨询公司(Capgemini)大数据战略主管,史蒂夫琼斯(Steve Jones)认为,面向服务的体系结构(SOA)思想将有助于组织机构管理大数据的繁荣,运用所需灵活性和敏捷性使其成为对公司有价值的业务。在其新文章中,琼斯呼吁将面向服务的思想延伸至数据环境。在他的想法中,SOA意味着摆脱僵化和整体进入系统的方法,将重要的成分分解成可处理的服务块。琼斯提出了一个“业务SOA”方法,这个方法将废除数据管理的整体方法,支持更灵活的、分布式方法。长久以来,数据及相关分析都被结构化为了&
摘要:为解决智能变电站建设周期相比传统变电站周期长的问题,通过对比分析两类变电站设计、调试过程的不同,提出将智能变电站的配置(设计)过程由系统集成商负责改为由设计部门管理配置(设计)网络平台完成。该平台基于SOA构架设计,根据设备提供商上传的IED设备的ICD文件,自动生成全站的SCD文件,进而生成各个IED装置的CID文件。设备提供商和系统集成商可以通过网络从该平台下载自己所需的CID或SCD文件。用户可以通过该平台对ICD、SCD、CID文件进行版本控制,进而约束各方的工作进度和质量。通过该平台用户调整了在整个智能变电站的设计、调试、建设过程中各个
今天下午,在IBM CDL(中国开发中心)举办的“企业内容管理核心客户高峰论坛”上,IBM发布了企业内容管理(ECM)的2010年战略——高级案例管理(Advanced Case Management,简称ACM)。这是IBM IM/BA(信息管理/业务分析)部门首次在全球率先发布这一解决方案的细节。据悉,IBM中国开发中心有大量研发人员和设计人员参与了该项目的研发过程中。企业内容管理作为随着数据管理 的发展而为客户提供的一种应用软件,它管理、集成和访问从音频、视频到扫描图像的各种格式的商业信息。内容管理
引言随着科技的迅速发展,社会对电力能源的需求越来越大。导致电力系统企业不断扩充,部门不断增加。伴随着信息化技术的迅猛发展。而且为了更好地满足电力客户需求并提高供电企业自身竞争力,电力企业越来越依赖于信息系统。然而,信息系统自身也面临着很大的压力,即异构和需求在不断地发生改变的问题。当前大多数企业都有各种各样的系统和应用,包含不同时期和不同技术的体系结构,难以集成来自多个厂商跨不同平台的产品,基础架构的变更和应用程序升级工作量很大。这样就需要建立一体化信息平台,用来解决上面提到的问题。而这个平台的核心架构就是面向服务架构(SOA)。它能够很好地解决一体化
近日,国家标准化管理委员会正式发布了2项由SOA分技术委员会(筹)负责起草的SOA国家标准,并定于2013年6月1日起正式实施。此次发布的“信息技术-面向服务的体系结构(SOA)-术语”及“信息技术-面向服务的体系结构(SOA)-应用的总体技术要求”两项标准均由我国自主制定,在我国SOA发展进程中具有里程碑意义。SOA概念诞生于1996年,发展至今,它已成为大型软件企业和具有大型IT架构的行业所最为关心的话题之一。基于SOA 构建信息系统,可以加快系统开发效率、充分整合和重用IT 资源、灵活快速地响应业务
一、前言随着社会信息化的不断发展,我国经济建设的不断推进,市场竞争也变得越来越激烈,因此,企业不但面临着良好的机遇,而且还面临着巨大的挑战。这也要求企业要不断的对自身的经营管理模式进行革新,只有这样才能够适应时代的发展,并且在激烈的市场竞争中获得更好的发展。就目前而言,CRM系统也得到了众多企业的青睐。而随着计算机科学技术和电子商务领域的发展,CRM系统已经逐渐的形成一种以信息技术为核心的智能化系统。二、对于SOA的介绍(一)SOA的基本概括所谓SOA,具体指的就是面向服务构架,它可以根据所需的要求通过网络技术对松散耦合的粗粒度应用组件进行分布式部署、
一、引言近年来,ERP在我国已被越来越多的企业认同和接受.实施ERP已成为企业信息化的重要标志之一。但目前大多数企业在应用ERP系统时均面临着以下两方面的问题:(一)系统重用和集成问题。首先,ERP系统其重点在于企业内部的管理,而对于企业外部信息的管理,其却很少涉及,因此,不能实现企业与供应商、企业与分销商之间的信息集成。其次,企业在信息化建设的过程中,由于多年来业务流程的变化和IT技术的发展,使企业内部沉淀了各种应用系统。而这些不同的应用系统之间及它们与ERP系统之间不能直接通信,成为一个个“信息孤岛”。而当企业总是希望能尽可
日前,在珠海市科技工贸和信息化局组织召开的“面向电力行业的基于SOA 架构的应用集成解决方案及其支撑平台”的验收会上,验收专家组一致同意由远光软件联合武汉大学承担的产学研结合项目通过验收。该项目整合远光软件、武汉大学软件工程国家重点实验室珠海研发中心双方的技术与人才资源,从数据、应用及流程三个层面进行电力行业IT 系统与应用系统整合研究,旨在形成电力行业较为完善的企业应用集成体系,促进行业软件运行平台和开发平台的协调发展。项目建设突破了异构数据整合及云计算虚拟化等关键技术难点,通过将已有系统的功能封装为接口明确的、标准化的、与具
曾经有人说云计算是过分炒作,还有人说它是虚假宣传。随着大数据的话题不断升温,云计算的温度也逐渐趋于平常。但在去过IBM中国研究中心之后,我发现这一观点并不准确,我看到云计算已经帮助一个企业成为主要收入来源之一。作为IBM中国开发中心CTO,IBM创新工程院院长毛新生他用了三个词介绍了云计算就是“simple,simple,simple”,他说:“云计算是一个可以帮助企业将业务优化,创新的平台。云计算是与大数据紧密相关的,而不是说大数据可以创造价值而云计算不能。”IBM中国开发中心CTO,IBM创新工程院院
请使用微信扫一扫
关注公众号完成登录
姓名: | |
性别: | |
出生日期: | |
邮箱: | |
所在地区: | |
行业类别: | |
工作经验: | |
学历: | |
公司名称: | |
任职岗位: |
我们将会第一时间为您推送相关内容!