Dubbo面试题

1. 那为什么要有 RPC,HTTP 不好么?

RPC 对比的是本地过程调用,是用来作为分布式系统之间的通信,它可以用 HTTP 来传输,也可以基于 TCP 自定义协议传输。

Dubbo 的注册中心集群挂掉,发布者和订阅者之间还能通信么? 可以通讯。启动 Dubbo 时,消费者会从 Zookeeper 拉取注册的生产者的地址接口等数据,缓存在本地。每次调用时,按照本地存储的地址进行调用。

2. Dubbo集群提供了哪些负载均衡策略?

Random LoadBalance: 随机选取提供者策略,有利于动态调整提供者权重。截面碰撞率高,调用次数越多,分布越均匀。 RoundRobin LoadBalance: 轮循选取提供者策略,平均分布,但是存在请求累积的问题。 LeastActive LoadBalance: 最少活跃调用策略,解决慢提供者接收更少的请求。 ConstantHash LoadBalance: 一致性 Hash 策略,使相同参数请求总是发到同一提供者,一台机器宕机,可以基于虚拟节点,分摊至其他提供者,避免引起提供者的剧烈变动。

3. Dubbo的集群容错方案有哪些?

Failover Cluster:失败自动切换,当出现失败,重试其它服务器。通常用于读操作,但重试会带来更长延迟。 Failfast Cluster:快速失败,只发起一次调用,失败立即报错。通常用于非幂等性的写操作,比如新增记录。 Failsafe Cluster:失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作。 Failback Cluster:失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作。 Forking Cluster:并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks="2″ 来设置最大并行数。 Broadcast Cluster:广播调用所有提供者,逐个调用,任意一台报错则报错 。通常用于通知所有提供者更新缓存或日志等本地资源信息。

默认的容错方案是 Failover Cluster。

相关推荐
二哈赛车手2 分钟前
新人笔记---责任链模式
后端
Darren2457 分钟前
Junit到Springboot单元测试
后端
张涛酱10745610 分钟前
「实战」Spring Boot 4.1.0-M3 新特性速览:gRPC、OpenTelemetry全面升级
后端
龙码精神11 分钟前
ClickHouse 容灾技术方案(两方案对比+落地细节)
后端·架构
bugcome_com11 分钟前
WPF 命令 ICommand 从原理到实战
后端·wpf·icommand
若水不如远方12 分钟前
分布式一致性(七):架构角度 —— 分布式共识系统的选型指南
分布式·后端
shark_chili15 分钟前
Spring 核心知识点全面解析
后端
WavesMan18 分钟前
YoBFF 实战复盘:让审计日志从“可用”走向“可运营
后端
SimonKing23 分钟前
企微、QQ统统接入OpenClaw,蓄水池已满,准备养虾
java·后端·程序员
CodeSheep30 分钟前
王自如公开招聘01号员工,这要求有多离谱?
前端·后端·程序员