1. Dubbo的快速讲解
以防有人对Dubbo不了解,快速过一下Dubbo的基本概念,下面简单引用一下官方的介绍
1.1 架构

1.2.角色说明
Provider:暴露服务的提供方
Consumer:远程服务的消费方
Register:服务注册与发现的注册中心
Monitor:统计服务调用次数和调用时间的监控中心
Container:服务运行容器
1.3.调用关系
0:服务容器负责启动,加载,运行服务提供者
1:服务提供者在启动时,向注册中心自己提供的服务
2:服务消费者在启动时,向注册中心订阅自己所需的服务
3:注册中心返回服务提供者地址给消费者,如果有变更,注册中心将基于长连接推送给服务消费者
4:服务消费者从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选一台
5:服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次数据到监控中心

2. Dubbo使用ZooKeeper注册中心
在使用Dubbo时,我们可以利用zookeeper生成的节点树,服务提供者在启动时候,将提供的服务名称和地址以节点的方式注册到服务器ZooKeeper的配置中心,然后消费者通过服务配置中心获取需要的服务名称下的服务地址,因为znode有非持久节点的特性,服务器可以动态的从服务配置中心移除,并且触发消费者的watcher方法。如下图所示:

流程如下:
(1)服务提供者启动时候向节点/dubbo/com.foo.BarService/providers写下自己的URL地址。
(2)服务消费者启动时,订阅/dubbo/com.foo.BarService/providers目录下的提供者URL地址,然后在consumers节点写入自己的URL
(3)Monitor启动时候,订阅/dubbo/com.foo.BarService下所有的服务提供者和消费者URL地址

同时具有以下的特性:
(1)当提供者出现断电等异常停机时,注册中心能自动删除提供者信息。
(2)当注册中心重启时,能自动恢复注册数据,以及订阅请求。
(3)当会话过期时,能自动恢复注册数据,以及订阅请求。

3. 结合实例查看
通过结合Spring,编写一个简单的实例。有利于理解ZooKeeper和Dubbo的结合, 具体请参见https://github.com/wacxt/zookeeper-study
Provider.java

package com.shaoqing.zookeeper2;

import java.io.IOException;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class Provider { private final static Logger logger = LoggerFactory.getLogger(Provider.class);
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
"classpath*:provider.xml");
context.start(); logger.info("provider begin to start");
try {
System.in.read();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

provider.xml

<?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"> <!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:application name="provider" /> <!-- 使用zookeeper暴露服务地址 -->
<dubbo:registry protocol="zookeeper" address="127.0.0.1:4399" /> <!-- 用dubbo协议在20881端口暴露服务 -->
<dubbo:protocol name="dubbo" port="20881" /> <!-- 声明需要暴露的服务接口 -->
<dubbo:service interface="com.shaoqing.zookeeper2.DemoService" ref="demoService" /> <!-- 和本地bean一样实现服务 -->
<bean id="demoService" class="com.shaoqing.zookeeper2.DemoServiceImpl" /> </beans>

Consumer.java

package com.shaoqing.zookeeper2;

import java.io.IOException;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class Consumer {
private final static Logger logger = LoggerFactory.getLogger(Consumer.class);
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
"classpath*:consumer.xml");
context.start();
DemoService demoService = (DemoService)context.getBean("demoService"); // 获取远程服务
String hello = demoService.sayHello("world"); // 执行远程方法
System.out.println( hello ); // 显示调用结果
}
}

Consumer.xml

<?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"> <dubbo:application name="consumer" /> <!-- 使用zookeeper暴露服务地址 -->
<dubbo:registry protocol="zookeeper" address="127.0.0.1:4399" /> <dubbo:reference id="demoService" interface="com.shaoqing.zookeeper2.DemoService" /> </beans>

上文还涉及到了一个类和一个接口,代码如下

package com.shaoqing.zookeeper2;

public interface DemoService {

    String sayHello(String name);

}

package com.shaoqing.zookeeper2;

public class DemoServiceImpl implements DemoService {

    public String sayHello(String name) {
return "Hello"+name;
} }

然后运行Provider.java和Consumer.java

接下来,我们就去分析此时ZooKeeper的情况
首先我们会看到此时已经有了dubbo结点和它的子结点了

接着查看providers结点的信息

然后把provider程序关闭,我们可以看到此时已经没有了它的信息,整个流程下来。我们可以看到两个结合使用带来的好处。

原文地址:https://blog.csdn.net/killuazoldyck/article/details/72804280

ZooKeeper系列(10):ZooKeeper与Dubbo的结合的更多相关文章

  1. 【Zookeeper系列】ZooKeeper管理分布式环境中的数据(转)

    原文地址:https://www.cnblogs.com/sunddenly/p/4092654.html 引言 本节本来是要介绍ZooKeeper的实现原理,但是ZooKeeper的原理比较复杂,它 ...

  2. 【Zookeeper系列】zookeeper面试题(转)

    原文链接:https://segmentfault.com/a/1190000014479433 1.ZooKeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是 ...

  3. 【Zookeeper系列】ZooKeeper一致性原理(转)

    原文链接:https://www.cnblogs.com/sunddenly/p/4138580.html 一.ZooKeeper 的实现 1.1 ZooKeeper处理单点故障 我们知道可以通过Zo ...

  4. 【Zookeeper系列】ZooKeeper机制架构(转)

    原文链接:https://www.cnblogs.com/sunddenly/p/4133784.html 一.ZooKeeper权限管理机制 1.1 权限管理ACL(Access Control L ...

  5. 【Zookeeper系列】Zookeeper命令操作(转)

    原文链接:https://www.cnblogs.com/sunddenly/p/4031881.html 一.Zookeeper的四字命令 Zookeeper支持某些特定的四字命令字母与其的交互.他 ...

  6. 【Zookeeper系列】ZooKeeper安装配置(转)

    原文链接:https://www.cnblogs.com/sunddenly/p/4018459.html 一.Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪 ...

  7. 【Zookeeper系列】Zookeeper简单介绍(转)

    原文链接:https://www.cnblogs.com/sunddenly/p/4033574.html 一.分布式协调技术 在给大家介绍ZooKeeper之前先来给大家介绍一种技术——分布式协调技 ...

  8. zookeeper系列之六—zookeeper之应用

    http://www.cnblogs.com/sharpxiajun/archive/2013/06/02/3113923.html Zookeeper是hadoop的一个子项目,虽然源自hadoop ...

  9. zookeeper系列之一—zookeeper入门

    Zookeeper是什么? Zookeeper故名思议动物管理员,它是拿来管大象(Hadoop).蜜蜂(Hive).小猪(Pig)的管理员,Apache Hbase和Apache Solr以及Link ...

随机推荐

  1. WinForm读取指定的config文件的内容

    config文件的使用 一.缘起 最近做项目开始使用C#,因为以前一直使用的是C++,因此面向对象思想方面的知识还是比较全面的,反而是因没有经过完整.系统的.Net方面知识的系统学习,经常被一些在C# ...

  2. java BitSet2

    15. int nextClearBit(int startIndex)返回第一个设置为 false 的位的索引,这发生在指定的起始索引或之后的索引上. 16. int nextSetBit(int ...

  3. Bartender 使用 Excel xlsx 数据库时出现 0x800A0E7A

    Bartender 使用 Excel 数据库时出现 0x800A0E7A 这是因为没有装 数据库驱动的原因. 安装微软的驱动就可以. 注意是安装 32 位的驱动. https://www.micros ...

  4. 关于fit和transform

    Fit是对于数据进行拟合,所谓拟合,就是根据数据,计算获得数据里面的一些指标,比如均值,方差:下一步很多API都是需要这些参数来进行后续对数据的操作,比如下面要讲到的transform. Transf ...

  5. 岭回归和Lasso回归以及norm1和norm2

    norm代表的是距离,两个向量的距离:下图代表的就是p-norm,其实是对向量里面元素的一种运算: 最简单的距离计算(规范)是欧式距离(Euclidean distance),两点间距离是如下来算的, ...

  6. ArrayBlcokingQueue,LinkedBlockingQueue与Disruptor三种队列对比与分析

    一.基本介绍 ArrayBlcokingQueue,LinkedBlockingQueue是jdk中内置的阻塞队列,网上对它们的分析已经很多,主要有以下几点: 1.底层实现机制不同,ArrayBlco ...

  7. Delphi实现软件中登录用户的操作权限

    数据库结构:包括两张表BaseData和UserRightData,BaseData中是一张基本表,里面不区分用户,UserRightData是用户权限表,结构和BaseData一样,只是多了用户字段 ...

  8. mac打开文件提示文件已经坏了的修改

    10.12下面,mac做了安全的限制,不能打开任意的文件,需要解除限制 sudo spctl --master-disable

  9. PPT资源

    PPT模板下载:www.1ppt.com/moban/ 行业PPT模板:www.1ppt.com/hangye/ 节日PPT模板:www.1ppt.com/jieri/ PPT素材下载:www.1pp ...

  10. 研究js特效巩固JavaScript知识

    400多个JavaScript特效大全,包含全部源代码和详细代码说明,不可多得 JavaScript实现可以完全自由拖拽的效果,带三个范例    http://www.sharejs.com/show ...