一 简介:

DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求。

Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。

其核心部分包含:

            Provider: 暴露服务的服务提供方。

           Consumer: 调用远程服务的服务消费方。

        Registry: 服务注册与发现的注册中心。

        Monitor: 统计服务的调用次调和调用时间的监控中心。

        Container: 服务运行容器。

二 调用过程:

服务容器负责启动,加载,运行服务提供者。

服务提供者在启动时,向注册中心注册自己提供的服务。

服务消费者在启动时,向注册中心订阅自己所需的服务。

注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。

服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。

服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

       Dubbo通常采用Zookeeper作为服务注册中心,存储服务的元数据,Zookeeper是基于观察者模式实现的数据库,他可以存储和管理数据,当数据发生变更时,它可以把这些变更通知在它上面注册的观察者们。服Zookeeper支持集群部署可以实现负载均衡。

三 使用方法:

使用dubbo前先启动zookeeper,dubbo通常采用zookeeper作为注册中心,这也是官方推荐的方式。

定义服务接口: (该接口需单独打包,在服务提供方和消费方共享)。

在服务提供方实现接口:(对服务消费方隐藏实现)。

       服务生产者配置:

 

<?xmlversion="1.0" encoding="UTF-8"?>
<beans  xmlns="http://www.springframework.org/schema/beans"
           xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
         http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
         http://code.alibabatech.com/schema/dubbo
         http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    <!-- 提供方应用名称信息,这个相当于起一个名字,我们dubbo管理页面比较清晰是哪个应用暴露出来的 -->
<dubbo:applicationname="dubbo-domain"/>
    <!-- 使用zookeeper注册中心作为dubbo的注册中心 -->
<dubbo:registry   protocol="zookeeper"address="172.16.7.177:2181"/>
    <!-- 用dubbo协议在20886端口暴露服务 -->
<dubbo:protocolname="dubbo" port="20886" />
    <!-- 声明需要暴露的服务接口 -->
    <dubbo:serviceinterface="itw.api.service.UserService"   ref="userService" />
</beans>
      
       服务消费者配置:
<?xml version="1.0"encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
         http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
         http://code.alibabatech.com/schema/dubbo
         http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<!-- 消费方应用名称信息,这个相当于起一个名字,我们dubbo管理页面比较清晰是哪个应用消费服务 -->
<dubbo:applicationname="dubbo-app"/>
    <!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry   protocol="zookeeper"address="172.16.7.177:2181"/>
   <dubbo:reference id="userService"  interface="itw.api.service.UserService"/>
</beans>

还有一些常用参数配置:

Version:服务版本,与服务提供者的版本一致

Group:服务分组,当一个接口有多个实现,可以用分组区分,必需和服务提供方一致

Timeout:服务方法调用超时时间(毫秒)

Retries:远程服务调用重试次数,不包括第一次调用,不需要重试请设为0

Loadbalance:负载均衡策略,可选值:random,roundrobin,leastactive

Check:启动时检查提供者是否存在,true报错,false忽略

url:点对点直连服务提供者地址,将绕过注册中心