Dubbo 是什么?
Dubbo 是一款高性能、轻量级的开源 RPC 框架,提供服务自动注册、自动发现等高效服务治理方
案,可以和 Spring 框架无缝集成。
Dubbo 的使用场景有哪些?
1、透明化的远程方法调用:就像调用本地方法一样调用远程方法,只需简单配置,没有任何 API
侵入。
2、软负载均衡及容错机制:可在内网替代 F5 等硬件负载均衡器,降低成本,减少单点。
3、服务自动注册与发现:不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的
IP 地址,并且能够平滑添加或删除服务提供者。
Dubbo 核心功能有哪些?
1、Remoting:网络通信框架,提供对多种 NIO 框架抽象封装,包括“同步转异步”和“请求-响应”模
式的信息交换方式。
2、Cluster:服务框架,提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均
衡,失败容错,地址路由,动态配置等集群支持。
3、Registry:服务注册,基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地
址透明,使服务提供方可以平滑增加或减少机器。
Dubbo 核心组件有哪些?
1、Provider:暴露服务的服务提供方
2、Consumer:调用远程服务消费方
3、Registry:服务注册与发现注册中心
4、Monitor:监控中心和访问调用统计
5 Container:服务运行容器
Dubbo 服务器注册与发现的流程?
1、Provider(提供者)绑定指定端口并启动服务。
2、提供者连接注册中心,并发本机 IP、端口、应用信息和提供服务信息发送至注册中心存储。
3、Consumer(消费者),连接注册中心,并发送应用信息、所求服务信息至注册中心。
4、注册中心根据消费者所求服务信息匹配对应的提供者列表发送至 Consumer 应用缓存。
5、Consumer 在发起远程调用时基于缓存的消费者列表择其一发起调用。
6、Provider 状态变更会实时通知注册中心、在由注册中心实时推送至 Consumer。