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。

相关推荐
波波烤鸭11 分钟前
Spring Boot 原理与性能优化实战
spring boot·后端·性能优化
shellvon14 分钟前
从抓包到攻防:解锁API安全设计的秘密
后端·安全
言之。17 分钟前
Django REST Framework响应类Response详解
后端·python·django
Abadbeginning25 分钟前
FastSoyAdmin centos7云服务器+宝塔部署
vue.js·后端·python
xuejianxinokok1 小时前
PostgreSQL 18 新功能:虚拟生成列
数据库·后端
未来影子1 小时前
SpringAI(GA):Neo4j向量数据库存储快速上手
后端
武子康1 小时前
大数据-95 Spark 集群 SparkSQL Action与Transformation操作 详细解释与测试案例
大数据·后端·spark
知其然亦知其所以然1 小时前
MySQL8.x 面试高频题:为什么一定要有主键?99%的人答不全
后端·mysql·面试
FE_C_P小麦1 小时前
Git 常用指令
前端·后端·github