Dubbo源码学习--webservice协议(十)

39人阅读 评论(0) 收藏 举报
分类:

基于 WebService 的远程调用协议,基于 Apache CXF 1 的 frontend-simple 和 transports-http 实现 2

可以和原生 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 应用的上下文路径相同。
1. CXF 是 Apache 开源的一个 RPC 框架,由 Xfire 和 Celtix 合并而来 
22.3.0 以上版本支持 ↩

WebserviceProtocol协议也是通过servlet容器对外暴露服务的,同样提供了doExport和doRefer两个接口对外暴露服务和引用服务

(1)doExport:对外暴露服务,webservice服务通过servlet容器对外暴露服务

//通过servlet容器对外暴露相关接口服务
    protected <T> Runnable doExport(T impl, Class<T> type, URL url) throws RpcException {
        String addr = getAddr(url);
        HttpServer httpServer = serverMap.get(addr);
        if (httpServer == null) {
            httpServer = httpBinder.bind(url, new WebServiceHandler());
            serverMap.put(addr, httpServer);
        }
        final ServerFactoryBean serverFactoryBean = new ServerFactoryBean();
		//地址信息
        serverFactoryBean.setAddress(url.getAbsolutePath());
		//接口类
        serverFactoryBean.setServiceClass(type);
		//实现类
        serverFactoryBean.setServiceBean(impl);
        serverFactoryBean.setBus(bus);
        serverFactoryBean.setDestinationFactory(transportFactory);
        serverFactoryBean.create();
        return new Runnable() {
            public void run() {
                serverFactoryBean.destroy();
            }
        };
    }

(2)doRefer:通过cxf框架创建相关webservice调用的代理类

protected <T> T doRefer(final Class<T> serviceType, final URL url) throws RpcException {
		//代理类工厂
        ClientProxyFactoryBean proxyFactoryBean = new ClientProxyFactoryBean();
		//设置webservice地址信息
        proxyFactoryBean.setAddress(url.setProtocol("http").toIdentityString());
		//服务提供信息
        proxyFactoryBean.setServiceClass(serviceType);
        proxyFactoryBean.setBus(bus);
		//创建相关代理信息
        T ref = (T) proxyFactoryBean.create();
        Client proxy = ClientProxy.getClient(ref);
        HTTPConduit conduit = (HTTPConduit) proxy.getConduit();
        HTTPClientPolicy policy = new HTTPClientPolicy();
        policy.setConnectionTimeout(url.getParameter(Constants.CONNECT_TIMEOUT_KEY, Constants.DEFAULT_CONNECT_TIMEOUT));
        policy.setReceiveTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT));
        conduit.setClient(policy);
        return ref;
    }


查看评论

基于Dubbo+Zookeeper实现webservice

  • 2016年12月20日 13:00
  • 42.22MB
  • 下载

dubbo webservice 协议的实现

1、新建dynamic web project ,名称:dubbo-webservice,如图: 2 、所使用jar 包括所有的Apache cxf  lib下的所有jar包,zkclient-0...
  • u012129031
  • u012129031
  • 2016-11-21 15:38:49
  • 6421

远程通信,Webservice、restful、dubbo

如何实现远程通信? 1、Webservice:效率不高基于soap协议,其主要的特点是跨语言、跨平台的。项目中不推荐使用,可用于不同公司间接口的调用。 2、使用restful形式的服务:http+...
  • dagreentree34521
  • dagreentree34521
  • 2017-03-18 13:02:12
  • 338

dubbo发布webservice服务

前面介绍了dubboframework基于dubbo协议的demo,这比给大家介绍另一种协议——webservice,其实它是基于http协议的实现,暴露wenservice的标准化接口,使用到apa...
  • zhangyunpengchang
  • zhangyunpengchang
  • 2016-06-02 14:49:44
  • 7146

Dubbo源码学习之知识点分析

最近听到有朋友公司用这个Dubbo,正好想了解一下源码。经过一小段时间分析,发现知识点非常多,很有价值。包括:动态代理,spring整合,各种设计模式,线程池,锁,netty这样基于nio的tcp框架...
  • herriman
  • herriman
  • 2016-05-28 15:37:01
  • 1673

dubbo:webservice基于servlet容器的实现demo

前面介绍了dubboframework基于dubbo协议的demo,这比给大家介绍另一种协议——webservice,其实它是基于http协议的实现,暴露wenservice的标准化接口,使用到apa...
  • joeyon
  • joeyon
  • 2015-07-03 14:17:53
  • 2733

使用dubbo+zookeper实现服务调用与使用webservice对比

使用dubbo+zookeper实现服务调用与使用webservice对比自己还是一个新手,就是想将学习到的东西记录下来,如果写错了还望见谅与纠正。webservice先说说webservice,在开...
  • chenhaotao
  • chenhaotao
  • 2017-11-08 14:18:14
  • 364

更好地学习dubbo源代码

Dubbo的官方首页在这里: http://code.alibabatech.com/wiki/display/dubbo/Home很荣幸,作为这样一款业界使用率和好评率出众的RPC框架的维护者,...
  • u012373815
  • u012373815
  • 2016-07-15 11:31:46
  • 638

基于Dubbo+Zookeeper 实现WebService

Dubbo+Zookeeper 创建webservice
  • qq_22313643
  • qq_22313643
  • 2016-12-20 13:03:17
  • 264

如何更好地学习dubbo源代码

Dubbo的官方首页在这里:http://code.alibabatech.com/wiki/display/dubbo/Home   很荣幸,作为这样一款业界使用率和好评率出众的RPC框架的维护者...
  • lidaasky
  • lidaasky
  • 2015-04-16 18:37:16
  • 3020
    个人资料
    专栏达人 持之以恒
    等级:
    访问量: 68万+
    积分: 1万+
    排名: 2163
    Github
    访问:https://github.com/IAMTJW
    博客专栏
    最新评论