一 简介:
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:点对点直连服务提供者地址,将绕过注册中心