zoukankan      html  css  js  c++  java
  • soa soap http rpc

    soa

    是一种计算机软件的设计模式,主要应用于不通应用组件中通过某种协议来互操作

    它的基本设计原理是:服务提供了一个简单的接口,抽象了底层的复杂性,然后用户可以访问独立的服务,而不需要去了解服务底层平台实现。

    基于SOA的解决方案,努力使经营目标而建立企业的质量体系。SOA架构是五层水平:

        1. 用户界面层–这些GUI的最终用户或应用程序访问的应用程序/服务接口。
        2. 业务流程层–这些精心设计的代表在应用方面的业务用例服务。
        3. 服务层–服务合并在一起,为整个企业提供实时服务。
        4. 服务组件层–用来建造服务的组件,如功能库和技术库,技术接口等。
        5. 操作系统–这层包含数据模型,企业数据仓库,技术平台等。

     

    正因为SOA架构实现不依赖于技术,因此能够被各种不同的技术实现。
    例如:
    SOAP
    RPC
    REST
    DCOM
    CORBA
    OPC-UA
    Web services
    DDS
    Java RMI
    WCF (Microsoft's implementation of web services now forms a part of WCF)
    Apache Thrift
    SORCER

    Web Service

    Web Service提供的服务是基于web容器的,底层使用http协议,类似一个远程的服务提供者,比如天气预报服务,对各地客户端提供天气预报,是一种请求应答的机制,是跨系统跨平台的。

    首先客户端从服务器得到Web Service的WSDL,同时在客户端声称一个代理类(Proxy Class) ,这个代理类负责与WebService服务器进行Request

    和Response。 当一个数据(XML格式的)被封装成SOAP格式的数据流发送到服务器端的时候,就会生成一个进程对象并且把接收到这个Request的SOAP包进行解析,然后对事物进行处理,处理结束以后再对这个计算结果进行SOAP包装,然后把这个包作为一个Response发送给客户端的代理类(Proxy Class),同样地,这个代理类也对这个SOAP包进行解析处理,继而进行后续操作。这就是WebService的一个运行过程。

    Web Service是一种标准,他可以通过soap或rest的方式来实现。

    传统的soap-webservice,使用了soap协议(基于xml包装)等。如果使用restful-webservice的话,则不需要soap与之相关的协议等,而是通过最简单的 http 协议传输数据 包括 xml 或 json) 。既简化了设计,也减少了网络传输量(因为只传输代表数据的 xml 或 json ,没有额外的 xml 包装)。

    Web Service主要涉及的概念:

     1. Http传输信道

     2. XML的数据格式

     3. SOAP封装格式

     4. WSDL的描述方式

     5. UDDI  UDDI是一种目录服务,企业可以使用它对Web Services进行注册和搜索

    SOAP(Simple Object Access Protocol)

    SOAP (Simple Object Access Protocol) 顾名思义,是一个严格定义的信息交换协议,用于在Web Service中把远程调用和返回封装成机器可读的格式化数据。事实上SOAP数据使用XML数据格式,定义了一整套复杂的标签,以描述调用的远程过程、参数、返回值和出错信息等等。而且随着需要的增长,又不得增加协议以支持安全性,这使SOAP变得异常庞大,背离了简单的初衷。另一方面,各个服务器都可以基于这个协议推出自己的API,即使它们提供的服务及其相似,定义的API也不尽相同,这又导致了WSDL的诞生。WSDL (Web Service Description Language) 也遵循XML格式,用来描述哪个服务器提供什么服务,怎样找到它,以及该服务使用怎样的接口规范,简言之,服务发现。现在,使用Web Service的过程变成,获得该服务的WSDL描述,根据WSDL构造一条格式化的SOAP请求发送给服务器,然后接收一条同样SOAP格式的应答,最后根据先前的WSDL解码数据。绝大多数情况下,请求和应答使用HTTP协议传输,那么发送请求就使用HTTP的POST方法。

    1、RPC与RMI

    (1)RPC 跨语言,而 RMI只支持Java。

    (2)RMI 调用远程对象方法,允许方法返回 Java 对象以及基本数据类型,而RPC 不支持对象的概念,传送到 RPC 服务的消息由外部数据表示 (External Data Representation, XDR) 语言表示,这种语言抽象了字节序类和数据类型结构之间的差异。只有由 XDR 定义的数据类型才能被传递, 可以说 RMI 是面向对象方式的 Java RPC 。

    (3)在方法调用上,RMI中,远程接口使每个远程方法都具有方法签名。如果一个方法在服务器上执行,但是没有相匹配的签名被添加到这个远程接口上,那么这个新方法就不能被RMI客户方所调用。

    在RPC中,当一个请求到达RPC服务器时,这个请求就包含了一个参数集和一个文本值,通常形成“classname.methodname”的形式。这就向RPC服务器表明,被请求的方法在为 “classname”的类中,名叫“methodname”。然后RPC服务器就去搜索与之相匹配的类和方法,并把它作为那种方法参数类型的输入。这里的参数类型是与RPC请求中的类型是匹配的。一旦匹配成功,这个方法就被调用了,其结果被编码后返回客户方。

  • 相关阅读:
    顧客満足度調査
    GeoStTool.dll过滤图层
    GeoStTool.ini相关技术要点
    GeoStTool.dll与RasterServer通信
    hdu 1007 Quoit Design
    hdu 4325 Flowers
    hdu 2516 取石子游戏
    hdu 1006 Tick and Tick
    CodeForces 101A Homework
    ZOJ Problem Set 1879
  • 原文地址:https://www.cnblogs.com/workstation-nigoudongma/p/9528516.html
Copyright © 2011-2022 走看看