Dubbo面试专题解析:注册中心、负载均衡策略及安全机制

需积分: 1 0 下载量 156 浏览量 更新于2024-08-03 收藏 402KB PDF 举报
Dubbo 面试专题及答案(下) Dubbo 是一个高性能、基于 Java 的 RPC 框架,提供了负载均衡、服务注册、服务发现、路由、监控等功能。下面是 Dubbo 面试专题及答案的详细知识点: 1.Dubbo 中 ZooKeeper 做注册中心,如果注册中心集群都挂掉,发布者和订阅者之间还能通信么? 可以通信的,因为启动 Dubbo 时,消费者会从 ZooKeeper 拉取注册的生产者的地址接口等数据,缓存在本地。每次调用时,按照本地存储的地址进行调用。注册中心对等集群,任意一台宕机后,将会切换到另一台;注册中心全部宕机后,服务的提供者和消费者仍能通过本地缓存通讯。服务提供者无状态,任一台宕机后,不影响使用;服务提供者全部宕机,服务消费者会无法使用,并无限次重连等待服务者恢复。 2.Dubbo 服务负载均衡策略? Dubbo 提供了四种负载均衡策略: * Random LoadBalance:随机,按权重设置随机概率。在一个截面上碰撞的概率高,但调用量越大分布越均匀,而且按概率使用权重后也比较均匀,有利于动态调整提供者权重。 * RoundRobin LoadBalance:轮循,按公约后的权重设置轮循比率。存在慢的提供者累积请求问题,比如:第二台机器很慢,但没挂,当请求调到第二台时就卡在那,久而久之,所有请求都卡在调到第二台上。 * LeastActive LoadBalance:最少活跃调用数,相同活跃数的随机,活跃数指调用前后计数差。使慢的提供者收到更少请求,因为越慢的提供者的调用前后计数差会越大。 * ConsistentHash LoadBalance:一致性 Hash,相同参数的请求总是发到同一提供者。当某一台提供者挂时,原本发往该提供者的请求,基于虚拟节点,平摊到其它提供者,不会引起剧烈变动。 3.Dubbo 在安全机制方面是如何解决的? Dubbo 通过 Token 令牌防止用户绕过注册中心直连,然后在注册中心上管理授权。Dubbo 还提供服务黑白名单,来控制服务所允许的调用方。 4.Dubbo 连接注册中心和直连的区别 Dubbo 连接注册中心时,服务提供者将自己的服务信息注册到注册中心,消费者通过注册中心来发现服务提供者。 Dubbo 直连时,消费者直接连接服务提供者,不需要通过注册中心。直连方式可以避免注册中心的单点故障,但需要手动配置服务提供者的地址。