转载:用于学习。
内容简介
SOA是英文Service-Oriented
Architecture,即面向服务架构的缩写。
这个词汇最近一两年频频出现在各种技术期刊上。但是一直以来对于SOA到底是什么没有明确的回答;
SOA有什么特点?
适合用于解决哪些问题?
与其他的技术有什么区别与联系?
Web
Service和SOA又是什么关系?
SOA的出现对于软件架构设计有什么影响?
本文将就上面提到的这些问题,尝试根据作者自己的理解给出SOA的定义;
总结出SOA特有的三个基本特征;然后以HTTP协议为例对这些特征进行解释;最后简要的说明SOA对今后软件架构设计可能带来的影响。
SOA定义
下面是作者给SOA下的一个定义:
SOA是指为了解决在Internet环境下业务集成的需要,通过连接能完成特定任务的独立功能实体实现的一种软件系统架构。
从这个定义中我希望表达的前提有下面两点:
1)
软件系统架构:SOA不是一种语言,也不是一种具体的技术而是一种软件系统架构,它尝试给出在特定环境下推荐采用的一种架构,从这个角度上来说,它更像一
种模式(Pattern)。因此它与很多已有的软件技术比如面向对象技术,是互补的而非互斥的。它们分别面向不同的应用场景,用来满足不同的特定需求。
2)
SOA的使用范围:需求决定同时也限制功能。SOA并不是包治百病的万灵丹,它最主要的应用场合在于解决在Internet环境下的不同商业应用之间的业
务集成问题。
在下面我们会详细讨论Internet的各种特点如何决定SOA的特点,这里我们只需要先简单回顾一下Internet环境区别于
Intranet环境的几个特点:
a) 大量异构系统并存,计算机硬件工作方式不同,操作系统不同、编程语言也不同;
b) 大量、频繁的数据传输仍然速度缓慢并且不稳定;
c) 版本升级无法完成,我们根本就无法知道互联网上有哪些机器直接或者间接的使用某个服务。
基于上面的前提,下面就让我们一起看一下SOA的基本特征。
SOA三大基本特征:
1 独立的功能实体
在Internet这样松散的使用环境中,任何访问请求都有可能出错,因此任何企图通过Internet进行控制的结构都会面临严重的稳定性问题。
SOA非常强调架构中提供服务的功能实体的完全独立自主的能力。传统的组件技术,如.NET
Remoting,EJB,COM或者CORBA,都需要有一个宿主(Host或者Server)来存放和管理这些功能实体;当这些宿主运行结束时这些组件的寿命也随之结束。这样当宿主本身或者其它功能部分出现问题的时候,在该宿主上运行的其它应用服务就会受到影响。
SOA架构中非常强调实体自我管理和恢复能力。常见的用来进行自我恢复的技术,比如事务处理(Transaction),消息队列(Message
Queue),冗余部署(Redundant Deployment)和集群系统(Cluster)在SOA中都起到至关重要的作用。
2 大数据量低频率访问
对于.NET
Remoting,EJB或者XML-RPC这些传统的分布式计算模型而言,他们的服务提供都是通过函数调用的方式进行的,一个功能的完成往往需要通过客户端和服务器来回很多次函数调用才能完成。在Intranet的环境下,这些调用给系统的响应速度和稳定性带来的影响都可以忽略不计,但是在
Internet环境下这些因素往往是决定整个系统是否能正常工作的一个关键决定因素。因此SOA系统推荐采用大数据量的方式一次性进行信息交换。
3 基于文本的消息传递
由于Internet中大量异构系统的存在决定了SOA系统必须采用基于文本而非二进制的消息传递方式。在COM、CORBA这些传统的组件模型中,从服务器端传往客户端的是一个二进制编码的对象,在客户端通过调用这个对象的方法来完成某些功能;但是在Internet环境下,不同语言,不同平台对数据、甚至是一些基本数据类型定义不同,给不同的服务之间传递对象带来的很大困难。由于基于文本的消息本身是不包含任何处理逻辑和数据类型的,因此服务间只传递文本,对数据的处理依赖于接收端的方式可以帮忙绕过兼容性这个的大泥坑。此外,对于一个服务来说,Internet与局域网最大的一个区别就是在Internet上的版本管理极其困难,传统软件采用的升级方式在这种松散的分布式环境中几乎无法进行。采用基于文本的消息传递方式,数据处理端可以只选择性的处理自己理解的那部分数据,而忽略其它的数据,从而得到的非常理想的兼容性。
HTTP协议:一个典型的SOA实现
每一项新技术都是在一些旧的技术基础上发展出来的。正如XML根本思想来自于在60年代就已经出现的早期标记性语言一样,SOA虽然这两年才出现,
但是它所表达的观念应该说在网络这种分布式系统结构出现不久就已经广泛应用了。例如我们最熟悉的HTTP协议就是一个非常典型的SOA架构设计。
HTTP
协议的工作过程简单叙述如下:
1) 客户端,通常是通过浏览器,向服务器端以文本的方式发送一个请求,索取一个Web页面;
2) 服务器端接收到这个请求之后,根据请求的内容进行处理并且返回一个符合HTML语法的文本;
3) 客户端接收到服务器端的响应文本后调用本地的程序,通常还是浏览器,把返回的HTML文本的内容展现出来。
下面来看一下HTTP协议如何满足了SOA的特点:
*
独立的功能实体:作为服务器端的Web服务器是绝对不会因为客户端的状况变化而改变的,它总是非常稳定地按照自己的内在逻辑运行,响应外部的请求,管理自
己的资源和数据。这里一个非常好的例子就是Web服务器对缓存(Cache)的处理,很多Web服务器为了提高性能都或多或少的对数据进行缓存,但是缓存
数据、刷新数据这些于客户端完全无关的操作完全由服务器端独立完成,完全不受客户端的影响。
*
大数据量低频率访问:对于一个HTTP请求来说,客户端与服务器之间访问的边界非常简单:就是一个请求,一个响应,没有任何其它的信息往返。无论客户端申
请的网页上除了文字之外还有什么信息,对于客户端来说,它发出的请求只是简单的告诉Web服务器它所需要的网页的位置;至于为了生成这个网页,服务器端是
否需要访问数据库,执行Servlet或者其它的CGI程序对客户端而言,都是完全透明的。
*
基于文本的消息传递:迄今为止兼容性最好的系统可能就是HTTP协议支撑的大部分的web应用了,我们可以在Windows平台下用IE查看互联网上一个
Linux+Apache服务器上的由Perl脚本自动生成的网页。这里的关键就是所有内容都是以格式化的文本方式传递的,不管Perl脚本如何执行,只要它的输出是符合HTML规范的网页,就可以被客户端的浏览器解释。而由于不同的操作系统上对于相同的HTML的解释遵循相同的规范,因此不同操作系统下仍然能够看到一致的用户界面。
我们上面基本描述了SOA作为一种软件架构有哪些特点,下面让我们一起看看:
Web Service与SOA
Web Service是就现在而言最适合实现SOA的一些技术的集合,事实上最近SOA的火爆在很大程度上归功于Web
Service标准的成熟和应用的普及为广泛的实现SOA架构提供了基础。
下面让我们看看Web
Service中的各种协议是如何互相工作来满足SOA所需的特点的:
* 独立的功能实体:通过UDDI的目录查找,我们可以动态改变一个服务的提供方而无需影响客户端的应用程序配置。所有的访问都通过SOAP访问进行,只要WSDL接口封装良好,外界客户端是根本没有办法直接访问服务器端的数据的。
*
大数据量低频率访问:通过使用WSDL和基于文本(Literal)的SOAP请求,我们可以实现能一次性接收大量数据的接口。这里需要着重指出的是
SOAP请求分文本方式和远程调用(RPC)两种方式,正如上文已经提到的,采用远程调用方式的SOAP请求并不符合这点要求。但是令人遗憾的是现有的大
多数SOAP请求采用的仍然是远程调用(RPC)方式,在某些平台上,例如IBM
WebSphere的早期版本,甚至没有提供文本方式的SOAP支持。
* 基于文本的消息传递:Web Service所有的通讯是通过SOAP进行的,而SOAP是基于XML的,不同版本之间可以使用不同的DTD或者XML Schema加以辨别和区分。因此只需要我们为不同的版本提供不同的处理就可以轻松实现版本控制的目标。
SOA对于软件架构设计的影响
无论您现在的系统是否牵涉到基于Internet的业务集成,采用SOA推荐的架构都对提高您系统的扩展性有很大帮助。
下面是在系统中引入SOA后需要在软件架构方面做出的改变:
* 使用基于文本方式的SOAP调用,摆脱远程调用中出现的函数参数类型等与数据无关的信息,保证所有SOAP传递的都是有意义的商业数据。依赖于Schema,而不是类定义对这些数据进行解释。
* 传统的三层Web应用将可能变成四层结构:传统意义上的商业逻辑层将被进一步划分为存放每个会话(Session)信息的客户逻辑层和与状态无关Sateless的SOA层。
分享到:
相关推荐
【用户画像准确性评测初探——拨开python大数据分析的神秘面纱】 用户画像准确性评测是数据分析领域中的一个重要环节,尤其在个性化推荐系统中,准确的用户画像能够提升用户体验和推荐效果。本文主要探讨了在2018年...
【拨开迷雾,回归价值:锻造资本市场管理能力】 中国的资本市场自1991年创立以来,历经30年快速发展,期间不断推出如“国九条”、上市保荐制度、社保基金入市、IPO注册制改革等创新举措,旨在推动市场的完善与成熟...
【拨开迷雾,回归价值:锻造资本市场管理能力】 中国的资本市场自1991年以来经历了快速的发展,特别是在2004年“国九条”推出后,一系列改革措施如上市保荐制度、社保基金入市和IPO注册制改革等,推动了市场的创新...
拨开阴霾,拥抱未来的自己.pdf
计算机网络是现代社会的基础,它使得分布在世界各地的计算机能够相互通信和交换数据,实现了资源的共享和信息的快速传递。...通过阅读本文,你将对计算机网络有更清晰的认识,从而能够拨开迷雾,直击网络的本质。
拨开信息化战场环境迷雾宣贯.pdf
标题“专题研究:拨开开年数据的三重迷雾”暗示了这是一个深入探讨新年初始阶段数据背后隐藏真相的研究报告。这份压缩包文件包含了一个名为“专题研究:拨开开年数据的三重迷雾.pdf”的PDF文档,很可能是详细的分析...
报告概述了2021年中国宏观经济的中期展望,主要探讨了两个核心问题:经济增长和信用变化。报告由国信证券经济研究所的分析师董德志撰写,分析了中国经济面临的"经济下行+通胀上行"困局,并提出了对资产配置的建议。...
中国ERP拨开云雾见太阳 第一章 中国ERP行业现状综述 5 1.1 中国ERP行业产品情况综述 5 1.2 目前市场上的ERP产品,在应用中出现的问题综述 6 1.3 目前市场上的ERP产品,在客户方没用好的原因综述 6 1.4 中国ERP行业的...
。云监控安全?拨开迷雾看云安防隐形功能.pdf
根据给定文件的信息,我们可以提炼出以下几个关键知识点: ### 一、宏观经济研究中的两大迷雾 #### 1.... - **确定性**:2021年四个季度的GDP同比增速呈现逐季下降的趋势。 - **不确定性**:这并不一定意味着实际...
传媒行业2020年策略报告:拨开云雾,蓄势待发
回到标题“拨开水藻露出一眼活泉”,它生动地比喻了当下的语文教学现状:表面热闹的课堂中,隐藏着学生真实学习需求的匮乏。只有拨开表面的浮华,关注学生实际的学习体验与收获,我们才能发现那眼能够滋养学生心灵的...
20221031华西证券网络安全行业深度报告(2)拨开云雾见天日,守得云开见月明共62页.pdf.zip
在标题“特斯拉电池日点评:拨开云雾见天日.pdf”中,关键词“特斯拉电池日”指代了特斯拉公司举办的关于电池技术发展的一次重要发布会,而“拨开云雾见天日”则暗含通过这次发布会,能够清晰地看到特斯拉电池技术...
原油季报:拨开黑天鹅的迷雾-0930-中粮期货-22页.pdf
原油季报:拨开黑天鹅的迷雾-20190930-中粮期货-22页.pdf
拨开云雾现真容 SQL语句显神通——宜春市应用计算机开展住房公积金审计纪实.pdf