zoukankan      html  css  js  c++  java
  • 常用协议 —— webservice://

    基于 WebService 的远程调用协议,基于 Apache CXF(Apache 开源的一个 RPC 框架)的 frontend-simple 和 transports-http 实现。

    可以和原生 WebService 服务互操作,即:

    • 提供者用 Dubbo 的 WebService 协议暴露服务,消费者直接用标准 WebService 接口调用,
    • 或者提供方用标准 WebService 暴露服务,消费方用 Dubbo 的 WebService 协议调用。

    依赖

    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-frontend-simple</artifactId>
        <version>2.6.1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http</artifactId>
        <version>2.6.1</version>
    </dependency>

    特性

    • 连接个数:多连接
    • 连接方式:短连接
    • 传输协议:HTTP
    • 传输方式:同步传输
    • 序列化:SOAP 文本序列化
    • 适用场景:系统集成,跨语言调用

    约束

    • 参数及返回值需实现 Serializable 接口
    • 参数尽量使用基本类型和 POJO

    配置

    配置协议:

    <dubbo:protocol name="webservice" port="8080" server="jetty" />

    配置默认协议:

    <dubbo:provider protocol="webservice" />

    配置服务协议:

    <dubbo:service protocol="webservice" />

    多端口:

    <dubbo:protocol id="webservice1" name="webservice" port="8080" />
    <dubbo:protocol id="webservice2" name="webservice" port="8081" />

    直连:

    <dubbo:reference id="helloService" interface="HelloWorld" url="webservice://10.20.153.10:8080/com.foo.HelloWorld" />

    WSDL:

    http://10.20.153.10:8080/com.foo.HelloWorld?wsdl

    Jetty Server (默认):

    <dubbo:protocol ... server="jetty" />

    Servlet Bridge Server (推荐):

    <dubbo:protocol ... server="servlet" />

    配置 DispatcherServlet:

    <servlet>
        <servlet-name>dubbo</servlet-name>
        <servlet-class>com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>dubbo</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>

    注意,如果使用 servlet 派发请求:

    • 协议的端口 <dubbo:protocol port="8080" /> 必须与 servlet 容器的端口相同,
    • 协议的上下文路径 <dubbo:protocol contextpath="foo" /> 必须与 servlet 应用的上下文路径相同。
  • 相关阅读:
    HTML技巧篇:如何让单行文本以及多行文本溢出时显示省略号(…)
    SpringMVC中响应json数据(异步传送)
    如何用Spring框架的<form:form>标签实现REST风格的增删改查操作
    如何使用REST请求风格
    Spring插件的安装与卸载---笔记
    元素 "context:component-scan" 的前缀 "context" 未绑定的解决方案
    简单的文件上传的下载(动态web项目)
    用简单的反射优化代码(动态web项目)
    json数据与Gson工具类的使用
    JSON简介
  • 原文地址:https://www.cnblogs.com/yifanSJ/p/9153424.html
Copyright © 2011-2022 走看看