一、SOA简介
1. SOA(面向服务架构)既是一种编程方式,也是软件开发的一种架构方法。根据这种架构方法,应用程序是由具有一定行为(称为服务)的功能单元组成的。
2. SOA的基本思想是构建一个粗粒度、松散耦合的系统,在这个系统中,服务的使用者与服务的实现唯一共同拥有的东西,就是公开的服务操作和参数的结构定义。
3. 客户端只知道用来描述服务方法的名称、输入参数类型及返回值类型。
4. SOA架构的技术基础是SOAP标准。SOAP用XML语言来定义一个服务操作所发送和接收消息的内容。该消息是由参数的值或者返回的值形成的,而且这些数据需要转换为SOAP格式。
二、SOA架构的4条原则
1. 边界显式定义
    只能通过调用契约才能执行服务中的逻辑。边界是指服务的公共接口与其内部专用实现之间的界线,边界必须显式定义,是指客户端程序只需要知道服务存在的方法,通过契约调用这些方法即可。
2. 服务是自治的
    服务是不依赖于其它服务行为的独立程序模块。服务必须经过部署,而且每个服务 的版本相互独立。
3. 服务共享的是模式和契约,而不是类
    模式是对服务操作的定义,它以一种独立于平台的方式来描述签名:方法的名称、参数类型和返回值类型。契约是服务的元数据,是服务作为黑盒子的对外接口,模式是对参数结构的定义。
4. 服务的兼容性是基于策略的
    这条原则意味着由服务决定在满足什么条件时才处理消息。为了通过协商确定通信中的元素,如消息的格式,安全性等要求,必须使用策略。策略用来进一步明确服务的语义和客户端对服务行为的期望。
三、服务的内部结构
1.  服务的工作原理
    
    一个服务包含若干个方法,这些方法通过一个通道与服务的使用者建立通信。服务的使用者也使用一个与服务通道相匹配的通道实际的调用服务的方法,向服务发送所需要的数据。一方面,通道是模式、契约和策略的结合;另一方面,通道在运行时就是使用的协议。消息可以在通道中双向传递。通道总是与某一个协议捆绑在一起,定义对服务的访问方式和访问过程。协议(如HTTP或MSMQ)用来传送数据,但需要得到服务实现时所在操作系统的支持(如MSMQ)。通道相当于一个管道,消息在其中流动。客户端把消息放在通道的一端,发布服务的平台所在的宿主栈在另一端读取消息。通道将被绑定由契约定义的模式上。在模式和契约中,如果没有对服务操作的元数据定义,那么通道是不完整的。通道还需要知道服务使用者必须实现的策略。
2.  服务的生态系统
1. 应用程序由服务组成
    这个生态系统的核心是服务,服务是组成模块,由它们构建应用程序。
2. 服务的管理状态
    服务的任务和操作经常把数据持久化的保存在数据库中,之后再从数据库中读取数据。
3. 服务实施策略
    服务有权指定和服务逻辑用法有关的策略。策略描述了服务使用者行为模式的先决条件。可以把策略当作在客户端与服务端通信之前必须达成的协议。绝大多数,它是关于安全的协议。
4. 策略实施操作要求
    通过定义策略,服务可以实施调用平台的操作要求。
5. 服务是由契约绑定的
    只有当描述服务操作签名的契约存在时,服务才存在。这个契约是客户与服务之间达成的约定。契约必须显式定义,并且在运行时要绑定到服务。建立客户端的代理类时,需要这个契约。
6. 契约描述了消息交换模式
    消息交换模式是对消息从一方到另一方传送过程和传送方法的定义。消息交换模式确定了同步还是异步调用服务,决定了是否需要返回结果。消息交换模式可以是:
    请求—响应模式:这是最常用的模式,每个调用都直接返回另一个消息。
    单向模式:服务调用没有返回结果,这种消息可以是异步调用的。
    双向模式:在调用方法的过程中那个,服务操作可以回调给客户端,服务操作在返回最终结果之前,可以向客户端程序请求更多的信息。
    消息交换模式在功能层是可见的,因此开发人员可以实现服务操作。在协议更深的技术层,消息交换模式虽然也存在,但大多数情况下是不可见的。
7. 契约包含模式,而模式定义消息的结构
    模式定义了所操作参数的结构。模式采用XSD文档格式来描述参数。XSD是元数据语言,用来描述传入服务操作的参数和服务操作返回的结果。
8. 服务交换模式是一个消息集
    消息的组合和调用顺序可以用一个更加复杂的交换模式来描述。这样依赖,消息交换模式就可以定义哪个操作必须先调用,哪个操作必须最后调用,以及决定是否定义操作的一个完整工作流。
9. 服务交换消息
    交换消息是服务生态系统的最重要组成部分。交换消息意味着调用一个操作和接受来自此操作的响应。
 
参考书籍:《WCF4高级编程》

[WCF编程]2.SOA概述的更多相关文章

  1. [WCF编程]4.契约概述

    一.契约的基本概念 契约是消息参与者之间的约定.在SOA架构中,契约提供了服务通信所必需的元数据.契约用来定义数据类型,操作,消息交换模式和消息交换使用的传输协议.契约通常是在标准化平台中使用与编程语 ...

  2. [WCF编程]5.绑定概述

    一.绑定概述 WCF提供了一个编程框架,可以抽象化服务创建的复杂过程.绑定允许开发人员将精力集中在问题本身上,而无需考虑如何创建允许系统运行的架构,因为WCF已经创建了架构. 绑定类型是开发人员控制W ...

  3. 【WCF--初入江湖】01 WCF编程概述

    01 WCF编程概述 SOA的优点 1.服务独立于平台和工作环境.服务并不关心自己所处的环境,也不关心与之进行通信的服务所处的    环境. 2.服务相互隔离. 3.服务对协议.格式和传输中立. 4. ...

  4. .Net-WCF-图书:《WCF编程》

    ylbtech-.Net-WCF-图书:<WCF编程> <WCF编程>是2008年1月机械工业出版社出版的图书,作者是Juval Lowy.Clemens Vasters. 1 ...

  5. WCF 编程实验室

    最近由于项目需要,简单研究了一下.NET WCF编程. 首先,简单说下WCF是什么,WCF 本质上,是一种开发框架.它用来开发类似COM+ .WEB SERVICE 这样“远程方法调用” 功能. 普通 ...

  6. WCF编程系列(七)信道及信道工厂

    WCF编程系列(七)信道及信道工厂   信道及信道栈 前面已经提及过,WCF中客户端与服务端的交互都是通过消息来进行的.消息从客户端传送到服务端会经过多个处理动作,在WCF编程模型中,这些动作是按层 ...

  7. WCF编程系列(六)以编程方式配置终结点

    WCF编程系列(六)以编程方式配置终结点   示例一中我们的宿主程序非常简单:只是简单的实例化了一个ServiceHost对象,然后调用open方法来启动服务.而关于终结点的配置我们都是通过配置文件来 ...

  8. WCF编程系列(四)配置文件

    WCF编程系列(四)配置文件   .NET应用程序的配置文件 前述示例中Host项目中的App.config以及Client项目中的App.config称为应用程序配置文件,通过该文件配置可控制程序的 ...

  9. WCF编程系列(五)元数据

    WCF编程系列(五)元数据   示例一中我们使用了scvutil命令自动生成了服务的客户端代理类: svcutil http://localhost:8000/?wsdl /o:FirstServic ...

随机推荐

  1. NodeJs 开发微信公众号(一)准备工作

    前言 大概是一个月前,自己用业余时间做了一个微信公众号.微信开发,尤其是对后台不熟悉的人来说显得尤其困难.首先要克服的是后台语言(nodejs)的一些不熟悉困难,其次,也是最大的一点困难是在跟微信交互 ...

  2. android服务里生成通知点击后返回正在运行的程序和当前的Activity

    想在服务里生成一个通知,并且点击通知打开当前应用程序下单当前活动,折腾了半天,网上的那些都不靠谱,试了半天,最后把ActivityManager和反射都用进来了,终于解决了这个问题.这样在服务中想恢复 ...

  3. awk 留底

      序   因为经常做awk编码,而且跨过一段时间就容易忘记,故在此做个留底.便于翻阅.——后期会在这个页面不断补充!   常用常量   属性 描述 NR  已读入的总记录数  ARGIND  当前被 ...

  4. Oracle客户端连接远程Oracle服务中文乱码问题

    在本机远程连接远程Oracle服务的时候,写了如下检索语句 select * from sys_employee 结果集中出现了中文乱码,但是远程服务器本身的PL/SQL检索出来没有问题 解决方案: ...

  5. 【Android环境搭建】解决安装使用SDK Manager更新时的问题

    问题描述: 安装使用SDK Manager更新时出现问题 Failed to fetch URL  https://dl-ssl.google.com/android/repository/repos ...

  6. Java针对数据库增删改查代码

    package com.bank.abc; import java.beans.PropertyVetoException; import java.sql.Connection; import ja ...

  7. C#并行编程系列-文章导航

    菜鸟初步学习,不对的地方请大神指教,参考<C#并行编程高级教程.pdf> 目录 C#并行编程-相关概念 C#并行编程-Parallel C#并行编程-Task C#并行编程-并发集合 C# ...

  8. java IO流 之 其他流

    一.内存操作流(ByteArrayInputStream.ByteArrayOutputStream) (一).   public class ByteArrayInputStream extends ...

  9. SikuliX简介及安装

    一.简单介绍 SikuliIDE和Sikuli Script就是现在的SikuliX,最新版本是SikuliX1.1.0, 部分兼容Sikuli JAVA API,支持Python和Ruby,Siku ...

  10. SSRS1:配置SMTP Server发送mail

    为了使用SSRS发送mail,必须为Reporting service配置SMTP Server. 1,在Reporting Service Configuration Manager中配置Email ...