Dubbo面试深度解析:30大核心问题

版权申诉
DOCX格式 | 443KB | 更新于2024-08-07 | 172 浏览量 | 0 下载量 举报
收藏
"Dubbo是一个高性能、轻量级的开源Java RPC框架,主要设计目标是提供一个简单、高效、可扩展的分布式服务解决方案。它在SOA架构中扮演着服务治理的角色,通过消除复杂的分布式环境中的通信问题,使服务提供者和服务消费者能够便捷地进行远程方法调用。Dubbo的核心特性包括服务注册与发现、负载均衡、容错机制、监控与管理等。" 1、为什么要用Dubbo? Dubbo旨在解决大型分布式系统中服务间的通信问题,提高系统的可伸缩性和高可用性。它提供了一种简单易用的API,使得开发者无需关心底层通信细节,专注于业务逻辑的实现。此外,Dubbo还支持服务治理,如服务注册、服务发现、熔断降级、负载均衡等,有助于系统稳定性和性能优化。 2、Dubbo的整体架构设计有哪些分层? Dubbo的架构主要包括:Provider(服务提供者)、Consumer(服务消费者)、Registry(注册中心)、Monitor(监控中心)四大部分。Provider暴露服务,Consumer调用服务,两者通过Registry进行服务的注册和发现,Monitor则用于收集服务调用的统计信息。 3、默认使用的是什么通信框架,还有别的选择吗? 默认使用Netty作为通信框架,但Dubbo也支持其他框架,如mina、grizzly等。 4、服务调用是阻塞的吗? Dubbo支持基于Future的非阻塞调用,但默认使用的是基于回调的阻塞调用模型。 5、一般使用什么注册中心?还有别的选择吗? 通常使用Zookeeper作为注册中心,但也可以选择Eureka、Consul或其他兼容的注册中心。 6、默认使用什么序列化框架,你知道的还有哪些? 默认使用Hessian2进行序列化,还可以选择Java自带的序列化、Fastjson、protobuf等。 7、服务提供者能实现失效踢出是什么原理? Dubbo通过心跳检测和健康检查机制来判断服务提供者的状态,当服务提供者无响应时,注册中心会将其标记为失效,并通知消费者停止调用。 8、服务上线怎么不影响旧版本? 通过版本管理和灰度发布,可以实现新旧版本并行运行,逐步将流量切换到新版本。 9、如何解决服务调用链过长的问题? 可以采用服务拆分、服务组合、熔断和降级策略,以及使用服务网格(如Istio)进行流量管理和路由优化。 10、说说核心的配置有哪些? 包括服务接口、服务版本、注册中心地址、超时时间、重试次数、负载均衡策略、序列化方式等。 11、Dubbo推荐用什么协议? 推荐使用高性能的Dubbo协议,也可以根据需求选择RMI、HTTP等其他协议。 12、同一个服务多个注册的情况下可以直连某一个服务吗? 可以通过指定服务的版本或分组来选择特定的服务实例。 13、服务注册与发现的流程图涉及服务提供者向注册中心注册服务,服务消费者订阅服务,注册中心推送服务列表,消费者根据服务列表进行调用。 14、Dubbo集群容错有几种方案? 包括Failover重试、Failfast快速失败、Failsafe静默失败、Failback重试、Forking并行调用、Broadcast广播调用等。 15、Dubbo服务降级和失败重试可以通过配置策略实现,如设置超时时间、重试次数,以及在服务不可用时执行默认操作。 16、Dubbo使用过程中可能遇到的问题包括网络延迟、服务雪崩、注册中心故障等,需要合理配置容错策略和监控。 17、DubboMonitor实现原理主要基于统计服务调用的QPS、响应时间等指标,提供可视化的监控界面。 18、Dubbo应用了多种设计模式,如工厂模式、代理模式、装饰器模式等,以实现其灵活可扩展的架构。 19、Dubbo配置文件通过Spring的Bean加载机制加载到Spring容器中,实现了服务的声明式配置。 20、Dubbo SPI(Service Provider Interface)与Java SPI的区别在于,Dubbo SPI提供了更丰富的扩展点和定制能力,包括自定义过滤器、适配器等。 21、Dubbo不直接支持分布式事务,但可以通过补偿事务(TCC)、消息队列等方式实现分布式事务。 22、Dubbo可以通过缓存中间件(如Redis)对结果进行缓存,减少重复调用。 23、服务上线兼容旧版本可通过版本控制、API兼容性设计以及回滚机制实现。 24、Dubbo必须依赖的包包括dubbo-core、dubbo-registry、dubbo-remoting等基础模块。 25、Dubbo telnet命令可用于服务查询、调用、监控等运维操作。 26、Dubbo支持服务降级,例如在服务不可用时返回默认值或抛出异常。 27、Dubbo优雅停机通常通过设置停止标志,等待当前请求处理完后再关闭服务。 28、Dubbo和Dubbox的区别在于,Dubbox是Dubbo的一个社区分支,增加了对异步调用、RESTful支持等新特性。 29、Dubbo和SpringCloud的区别在于,Dubbo侧重于RPC服务调用,而SpringCloud是一个完整的微服务解决方案,包括服务发现、配置中心、熔断器等组件。 30、其他的分布式框架包括Spring Cloud、Service Mesh(Istio、Linkerd等)、Apache Thrift、gRPC等,它们各有特点,适用于不同的场景和需求。

相关推荐