ZooKeeper系列(10):ZooKeeper与Dubbo的结合
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的结合的更多相关文章
- 【Zookeeper系列】ZooKeeper管理分布式环境中的数据(转)
原文地址:https://www.cnblogs.com/sunddenly/p/4092654.html 引言 本节本来是要介绍ZooKeeper的实现原理,但是ZooKeeper的原理比较复杂,它 ...
- 【Zookeeper系列】zookeeper面试题(转)
原文链接:https://segmentfault.com/a/1190000014479433 1.ZooKeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是 ...
- 【Zookeeper系列】ZooKeeper一致性原理(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4138580.html 一.ZooKeeper 的实现 1.1 ZooKeeper处理单点故障 我们知道可以通过Zo ...
- 【Zookeeper系列】ZooKeeper机制架构(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4133784.html 一.ZooKeeper权限管理机制 1.1 权限管理ACL(Access Control L ...
- 【Zookeeper系列】Zookeeper命令操作(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4031881.html 一.Zookeeper的四字命令 Zookeeper支持某些特定的四字命令字母与其的交互.他 ...
- 【Zookeeper系列】ZooKeeper安装配置(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4018459.html 一.Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪 ...
- 【Zookeeper系列】Zookeeper简单介绍(转)
原文链接:https://www.cnblogs.com/sunddenly/p/4033574.html 一.分布式协调技术 在给大家介绍ZooKeeper之前先来给大家介绍一种技术——分布式协调技 ...
- zookeeper系列之六—zookeeper之应用
http://www.cnblogs.com/sharpxiajun/archive/2013/06/02/3113923.html Zookeeper是hadoop的一个子项目,虽然源自hadoop ...
- zookeeper系列之一—zookeeper入门
Zookeeper是什么? Zookeeper故名思议动物管理员,它是拿来管大象(Hadoop).蜜蜂(Hive).小猪(Pig)的管理员,Apache Hbase和Apache Solr以及Link ...
随机推荐
- C#窗体模拟键盘按键(组合键)产生事件 ---- 通过keybd_event()函数
如何模拟键盘按键触发产生的事件,比如模拟按下Alt + F4 关闭当前程序,Ctrl+Shift 切换输入法等 可以通过win32api 键盘事件 keybd_event() 来实现 1.定义键盘按键 ...
- 客户端代码压缩成zip和服务器开启gzip
1.我说的zip是打包完的js代码,用压缩工具压缩为zip文件,这样放CDN上,下载量会进一步缩小,提高进入游戏的速度 嗯,需要在游戏页用js解压zip文件 2.最简单的就服务器开启gzip
- 建立你第一个 Outlook Add-in
最近因为工作需要,研究了下Outlook Add-in 和 Graph API.下面带大家建立一个Hello World 项目 建立Add-in 先前需求: Node.js 使用cmd/PowerSh ...
- ML(附录1)——梯度下降
梯度下降是迭代法的一种,可以用于求解最小二乘问题(线性和非线性都可以).在求解机器学习算法的模型参数,即无约束优化问题时,梯度下降(Gradient Descent)是最常采用的方法之一,另一种常用的 ...
- [转]B树(多向平衡查找树)详解
B-树是对2-3树数据结构的扩展.它支持对保存在磁盘或者网络上的符号表进行外部查找,这些文件可能比我们以前考虑的输入要大的多(以前的输入能够保存在内存中). (B树和B+树是实现数据库的数据结构,一般 ...
- Django 模板语法
模板语法之变量 变量在HTML中的表示:{{var_name}} 变量取值:句点符 "." views: def index(request): import datetime s ...
- tob toc tovc什么意思
先说一下TOB.TOC.TOVC的含义.B:business (企业)C:customer(消费者)VC:Venture Capital(风险投资) to b产品是根据公司战略或工作需要,构建生态体系 ...
- 跟着未名学 - 录屏套件 Camtasia Studio
目录 Camtasia Recorder. 1 Camtasia Studio.. 2 时间线... 2 渲染... 5 Camtasia MenuMaker. 6 Camtasia Play. 6 ...
- ALGO-152_蓝桥杯_算法训练_8-2求完数
记: 掌握完数的概念 AC代码: #include <stdio.h> int main(void) { int i,j,sum; ; i <= ; i ++) { sum = ; ...
- googletest--测试控制
有时候如果某个测试出现了异常,但是我们想继续其他的测试怎么办. 最简单的方法就是,在测试的名字前加上"DISABLED_",如下面的例子所示: // Test with fixtu ...