动力节点首页 全国咨询热线:400-8080-105

绑定手机号,登录
手机号

验证码

微信登录
手机号登录
手机号

验证码

微信登录与注册
微信扫码登录与注册

扫码关注微信公众号完成登录与注册
手机号登录
首页 > 文章

Dubbo服务调用过程

07-12 12:47 656浏览
举报 T字号
  • 大字
  • 中字
  • 小字

1.首先,启动服务提供者模块dubbo-provider。这时候,向注册中心注册自己提供的服务,也就是,在ZooKeeper上创建对应的临时子节点。

打开ZooKeeper可视化客户端,可以看到这样子一个目录结构:

在dubbo根节点下,会产生一个以接口名称命名的子节点,该节点为永久节点(因为接口名称不会经常变化)。接口节点下面,会有四个子节点,分别表示消费者、配置项、路由器、提供者。提供者节点下面,会有一个dubbo协议地址的子节点,这个节点就是我们启动服务容器时注册的服务了,如果还有其它的该接口实现类服务提供者,就会在同级目录再创建一个临时节点。为什么是临时节点呢?第一,服务提供者的地址是经常发生变化的;第二,如果提供者的服务器宕机了,跟ZooKeeper会话结束导致临时节点被删除,就可以自动通知注册了该节点事件监听的客户端。

附上Dubbo-Admin上面的信息

2.然后,启动服务消费者模块dubbo-consumer,这时候,向注册中心订阅自己所需的服务,也就是,获取ZooKeeper的对应目录子节点,然后保存到本地。

再看ZooKeeper的目录结构:

在consumers节点下多了一个临时节点(采用临时节点是因为客户端断开连接时可以自动删除) 。

3.服务调用的时候,在本地的服务提供列表中,基于软负载(RPC框架基本上都提供了本地负载均衡功能) 算法,找到合适的服务,然后进行远程调用。如果调用失败,选择另一台服务进行调用,这是容错功能。

Dubbo提供了多种负载均衡算法和容错采用措施提供配置。

动力节点在线课程涵盖零基础入门,高级进阶,在职提升三大主力内容,覆盖Java从入门到就业提升的全体系学习内容。全部Java视频教程免费观看,相关学习资料免费下载!对于火爆技术,每周一定时更新!如果想了解更多相关技术,可以到动力节点在线免费观看Dubbo框架视频教程学习哦!

0人推荐
共同学习,写下你的评论
0条评论
代码小兵872
程序员代码小兵872

30篇文章贡献98658字

相关课程 更多>

作者相关文章更多>

推荐相关文章更多>

Java面试题及答案整理

提枪策马乘胜追击04-21 20:01

Spring常见面试题

代码小兵92504-17 16:07

Java零基础实战项目——五子棋

代码小兵98804-25 13:57

Java string类详解

杨晶珍05-11 14:54

6道经典算法面试题

杨晶珍05-12 16:39

发评论

举报

0/150

取消