dubbo--多协议使用

一个服务提供多个协议

服务提供方:

服务提供两个协议:dubbo、hessian

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://code.alibabatech.com/schema/dubbo
        http://code.alibabatech.com/schema/dubbo/dubbo.xsd" default-autowire="byName">
    <context:annotation-config></context:annotation-config>
    <context:component-scan base-package="com.gupao.vip.mic.dubbo.order"/>
    <!--name:当前项目在整个分布式架构里面的唯一名称,计算依赖关系的标签 owner表示当前application是由谁维护-->
    <dubbo:application name="order-provider" owner="mic"/>
    <!--能对服务调用进行监控-->
    <!--<dubbo:monitor protocol="registry"/>-->
    <!--dubbo这个服务所要暴露的服务地址所对应的注册中心-->
    <dubbo:registry protocol="zookeeper" address="192.168.70.63:2181,192.168.70.64:2181,192.168.70.65:2181,192.168.70.66:2181"/>
    <!--当前服务发布所依赖的协议:webservice Thrift Hession http-->
    <dubbo:protocol name="dubbo" port="20880"/>
    <!--指定hessian协议-->
    <dubbo:protocol name="hessian" port="8090" server="jetty"/>
    <!--服务发布的配置,需要暴露的服务接口-->
    <dubbo:service interface="com.gupao.vip.mic.dubbo.order.IOrderServices" ref="orderService" protocol="dubbo"/>
    <dubbo:service interface="com.gupao.vip.mic.dubbo.order.IOrderQueryService" ref="orderQueryService" protocol="hessian"/>
</beans>

 

注册中心节点下生成两个url,,分别为dubbo、hessian协议

zk: localhost:2181(CONNECTED) 11] ls /dubbo/com.gupao.vip.mic.dubbo.order.IOrderQueryService/providers
[hessian%3A%2F%2F192.168.19.56%3A8090%2Fcom.gupao.vip.mic.dubbo.order.IOrderQueryService%3Fanyhost%3Dtrue%26application%3Dorder-provider%26dubbo%3D2.5.3%26interface%3Dcom.gupao.vip.mic.dubbo.order.IOrderQueryService%26methods%3DdoQuery%26owner%3Dmic%26pid%3D7904%26server%3Djetty%26side%3Dprovider%26timestamp%3D1550129252469]
[zk: localhost:2181(CONNECTED) 12] ls /dubbo/com.gupao.vip.mic.dubbo.order.IOrderServices/providers    
[dubbo%3A%2F%2F192.168.19.56%3A20880%2Fcom.gupao.vip.mic.dubbo.order.IOrderServices%3Fanyhost%3Dtrue%26application%3Dorder-provider%26dubbo%3D2.5.3%26interface%3Dcom.gupao.vip.mic.dubbo.order.IOrderServices%26methods%3DdoOrder%26owner%3Dmic%26pid%3D9316%26side%3Dprovider%26timestamp%3D1550130280940]

消费端:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
       http://code.alibabatech.com/schema/dubbo
       http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    <!--name:当前项目在整个分布式架构里面的唯一名称,计算依赖关系的标签 owner表示当前application是由谁维护-->
    <dubbo:application name="order-user" owner="mic"/>
    <!--dubbo这个服务所要暴露的服务地址所对应的注册中心-->
    <dubbo:registry address="zookeeper://192.168.70.66:2181?backup=192.168.70.65:2181,192.168.70.64:2181,192.168.70.63:2181"/>
    <!--生成一个远程服务的调用代理:check设置false,表示消费端启动时并不检查服务端是否启动,场景:出现循环依赖时-->
    <dubbo:reference id="orderService1"
                     interface="com.gupao.vip.mic.dubbo.order.IOrderServices"
                     check="false"
                     protocol="dubbo"/>
    <dubbo:reference id="orderQueryServices" interface="com.gupao.vip.mic.dubbo.order.IOrderQueryService" protocol="hessian"/>

</beans>

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值