【框架面试】Dubbo基础

2020-05-29  本文已影响0人  runewbie

1、Dubbo 是什么?

2、为什么需要服务治理?

dubbo-service-governance

3、Dubbo 的主要应用场景?

4、Dubbo 的核心功能?

主要就是如下3个核心功能:

4、Dubbo 的核心组件?

组件 说明
Provider 暴露服务的服务提供方
Consumer 调用远程服务的服务消费方
Registry 服务注册与发现的注册中心
Monitor 统计服务的调用次数和调用时间的监控中心
Container 服务运行容器

5、Dubbo 服务注册与发现的流程?

dubbo-relation

流程说明:

设计的原因:

6、Dubbo 的架构设计?

dubbo-framework

Dubbo框架设计一共划分了10个层:

7、Dubbo 的服务调用流程?

dubbo-extension

8、Dubbo 的注册中心集群挂掉,发布者和订阅者之间还能通信么?

可以的,启动dubbo时,消费者会从 zookeeper 拉取注册的生产者的地址接口等数据,缓存在本地。每

9、Dubbo 与 Spring 的关系?

Dubbo 采用全 Spring 配置方式,透明化接入应用,对应用没有任何 API 侵入,只需用 Spring 加载 Dubbo 的配置即可,Dubbo 基于 Spring 的 Schema 扩展进行加载。

10、Dubbo 使用的是什么通信框架?

默认使用 NIO Netty 框架

11、Dubbo 集群提供了哪些负载均衡策略?

缺省时为Random随机调用

12、Dubbo 的集群容错方案有哪些?

13、Dubbo 的默认集群容错方案?

Failover Cluster

14、Dubbo 支持哪些协议,每种协议的应用场景,优缺点?

15、Dubbo 推荐用什么协议?

默认使用 dubbo 协议

16、Dubbo 有些哪些注册中心?

17、Dubbo 默认采用注册中心?

采用 Zookeeper

18、Dubbo 支持哪些序列化方式?

默认使用 Hessian 序列化,还有 Duddo、FastJson、Java 自带序列化。

19、Dubbo 超时时间怎样设置?

Dubbo 超时时间设置有两种方式:

20、服务调用超时问题怎么解决?

dubbo 在调用服务不成功时,默认是会重试两次的。

21、Dubbo 在安全机制方面是如何解决?

Dubbo 通过 Token 令牌防止用户绕过注册中心直连,然后在注册中心上管理授权。Dubbo 还提供服务黑白名单,来控制服务所允许的调用方。

22、Dubbo 和 Dubbox 之间的区别?

dubbox 基于 dubbo 上做了一些扩展,如加了服务可 restful 调用,更新了开源组件等。

23、Dubbo 和 Spring Cloud 的区别?

组件 Dubbo Spring Cloud
服务注册中心 Zookeeper Spring Cloud Netfix Eureka / Nacos
服务调用方式 RPC REST API
服务网关 Spring Cloud Zuul / Spring Cloud Gateway
断路器 不完善 Spring Cloud Netfix Hystrix
分布式配置 Spring Cloud Config
服务跟踪 Spring Cloud Sleuth
消息总栈 Spring Cloud Bus
数据流 Spring Cloud Stream
批量任务 Spring Cloud Task

最大的区别:Dubbo 底层是使用 Netty 这样的 NIO 框架,是基于 TCP 协议传输的,配合以 Hession 序列化完成 RPC 通信。
而 SpringCloud 是基于 Http 协议 + Rest 接口调用远程过程的通信,相对来说,Http 请求会有更大的报文,占的带宽也会更多。但是 REST 相比 RPC 更为灵活,服务提供方和调用方的依赖只依靠一纸契约,不存在代码级别的强依赖。

上一篇 下一篇

猜你喜欢

热点阅读