1.Dubbo
是一款高性能、轻量级的开源
RPC
框架。由
10
层模式构成,整个分层
依赖由上至下
2.我们也可以将
Dubbo
理解为三层模式:
第一层的
Business
业务逻辑层由我们自己来提供接口和实现还有一些配置信息。
第二层的
RPC
调用的核心层负责封装和实现整个
RPC
的调用过程、负载均衡、
集群容错、代理等核心功能。
Remoting
则是对网络传输协议和数据转换的封装。
跟着Mic学架构
根据
Dubbo
官方文档的介绍,
Dubbo
提供了六大核心能力
面向接口代理的高性能
RPC
调用。
智能容错和负载均衡。
服务自动注册和发现。
高度可扩展能力。
运行期流量调度。
可视化的服务治理与运维。
3.既然说到
Dubbo
的功能,请详细说说
Dubbo
负载均衡的几种策略
Dubbo
有五种负载策略:
第一种是加权随机:假设我们有一组服务器
servers = [A, B, C]
,他们对应的权
重为
weights = [5, 3, 2]
,权重总和为
10
。现在把这些权重值平铺在一维坐标值
上,
[0, 5)
区间属于服务器
A
,
[5, 8)
区间属于服务器
B
,
[8, 10)
区间属于服
务器
C
。接下来通过随机数生成器生成一个范围在
[0, 10)
之间的随机数,然后
计算这个随机数会落到哪个区间上就可以了。
第二种是最小活跃数:每个服务提供者对应一个活跃数
active
,初始情况下,
所有服务提供者活跃数均为
0
。每收到一个请求,活跃数加
1
,完成请求后则将
活跃数减
1
。在服务运行一段时间后,性能好的服务提供者处理请求的速度更快,
因此活跃数下降的也越快,此时这样的服务提供者能够优先获取到新的服务请求。
第三种是一致性
hash
:通过
hash
算法,把
provider
的
invoke
和随机节点生成
hash
,并将这个
hash
投射到
[0, 2^32 - 1]
的圆环上,查询的时候根据
key
进
行
md5
然后进行
hash
,得到第一个节点的值大于等于当前
hash
的
invoker
。
第四种是加权轮询:比如服务器
A
、
B
、
C
权重比为
5:2:1
,那么在
8
次请求中,
服务器
A
将收到其中的
5
次请求,服务器
B
会收到其中的
2
次请求,服务器
C
则收到其中的
1
次请求。
第五种是最短响应时间权重随机: 计算目标服务的请求的响应时间,根据响应
时间最短的服务,配置更高的权重进行随机访问。
面试官:
Dubbo
的工作原理是什么样的?
高手:
跟着Mic学架构
1.
服务启动的时候,
provider
和
consumer
根据配置信息,连接到注册中心
register
,分别向注册中心注册和订阅服务
2.register
根据服务订阅关系,返回
provider
信息到
consumer
,同时
consumer
会把
provider
信息缓存到本地。如果信息有变更,
consumer
会收到来自
register
的推送
3.consumer
生成代理对象,同时根据负载均衡策略,选择一台
provider
,同时
定时向
monitor
记录接口的调用次数和时间信息
4.
拿到代理对象之后,
consumer
通过代理对象发起接口调用
5.provider
收到请求后对数据进行反序列化,然后通过代理调用具体的接口实现
面试官:最后在说说
Dubbo
与
Spring Cloud
的区别吧!
Dubbo
是
SOA
时代的产物,它的关注点主要在于服务的调用,流量分发、流
量监控和熔断。而
Spring Cloud
诞生于微服务架构时代,考虑的是微服务治理
的方方面面,另外由于依托了
Spirng
、
Spirng Boot
的优势之上,两个框架在
开始目标就不一致,
Dubbo
定位服务治理、
Spirng Cloud
是一个生态。
两者最大的区别是
Dubbo
底层是使用
Netty
这样的
NIO
框架,是基于
TCP
协议传输的,配合以
Hession
序列化完成
RPC
通信。而
SpringCloud
是基
于
Http
协议
+Rest
接口调用远程过程的通信,相对来说,
Http
请求会有更大
的报文,占的带宽也会更多。但是
REST
相比
RPC
更为灵活,服务提供方和调
用方的依赖只依靠一纸契约,不存在代码级别的强依赖。