文章目录
1 Dubbo
1.1 什么是dubbo
Dubbo |ˈdʌbəʊ| 是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。(官网:Dubbo官网)
1.2 发展史
1.3 Dubbo 架构
节点角色说明
- 服务提供者(Provider)︰暴露服务的服务提供方,服务提供者在启动时,向注册中心注册自己提供的服务。
- 服务消费者(Consumer):调用远程服务的服务消费方,服务消费者在启动时,向注册中心订阅自己所需的服务,服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
- 注册中心(Registry):注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
- 监控中心(Monitor):服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
调用关系说明
- 服务容器负责启动,加载,运行服务提供者。
- 服务提供者在启动时,向注册中心注册自己提供的服务。服务消费者在启动时,向注册中心订阅自己所需的服务。
- 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
- 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
- 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
1.4 引入Zookeeper
关于 1.3 中的注册中心,Dubbo官方推荐使用 Zookeeper 注册中心
2 Zookeeper 的安装与配置
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。
Dubbo 中的注册中心,官方推荐使用 Zookeeper
安装配置可参考文章:【踩坑三次】新版Zookeeper安装与配置:闪退、错误: 找不到或无法加载主类QuorumPeerMain、ZooKeeper audit is disabled
3 Dubbo Admin 的安装与配置
Dubbo Admin 是一个注册中心(比如Zookeeper)的可视化管理工具,可以查看我们注册了哪些服务,哪些服务被消费了等等
安装配置可参考文章:【踩坑四次】Dubbo-admin 安装与配置详细教程 + 排错解析
4 Dubbo + Zookeeper + Dubbo Admin 服务注册发现实战
可参考文章:SpringBoot集成 Dubbo + Zookeeper + Dubbo Admin:服务注册发现实战与详细步骤