跳至主要內容
Dubbo 面试之应用

Dubbo 面试之应用

简介

【简单】Dubbo 是什么?为什么使用 Dubbo?

Dubbo 是一款高性能、轻量级的开源 Java RPC 框架。

Dubbo 提供了三大核心能力:

  • 面向接口的远程过程调用(RPC):提供高性能的基于代理的远程调用能力,服务以接口为粒度,为开发者屏蔽远程调用底层细节。
  • 智能容错和负载均衡:内置多种负载均衡策略,智能感知下游节点健康状况,显著减少调用延迟,提高系统吞吐量。
  • 服务自动注册和发现:支持多种注册中心服务,服务实例上下线实时感知。

钝悟...大约 16 分钟分布式分布式通信RPC分布式通信RPC微服务Dubbo面试
Dubbo 面试之服务治理

Dubbo 面试之服务治理

服务注册和发现

【中等】什么是服务注册与发现?Dubbo 如何实现?

什么是服务注册与发现?

服务注册与发现是微服务的核心基础设施,通过解耦服务地址硬编码,实现动态扩缩容故障自动恢复

  • 服务注册(Registration):服务提供者(Provider)启动时,将自己的 IP、端口、接口名 等信息上报到注册中心(如 Zookeeper/Nacos)。举例订单服务启动后,向注册中心注册:"order-service: 192.168.1.100:8080"
  • 服务发现(Discovery):服务消费者(Consumer)从注册中心 拉取可用服务列表,并基于负载均衡策略选择目标实例。举例支付服务需要调用订单服务时,从注册中心获取所有可用的order-service节点列表。

钝悟...大约 34 分钟分布式分布式通信RPC分布式通信RPC微服务Dubbo面试服务治理
Dubbo 面试之架构

Dubbo 面试之架构

调用流程

【简单】Dubbo 支持哪些序列化方式?

  • Hessian(默认)
    • 特点:二进制格式,速度较快,体积较小
    • 适用场景:通用 RPC 调用(Dubbo 默认方案)
    • 缺点:对复杂对象支持有限
  • JSON
    • 特点:文本格式,可读性强,跨语言支持好
    • 适用场景:前后端交互、多语言系统
    • 缺点:性能较差,数据体积大
  • Java 原生序列化
    • 特点:JDK 内置,使用简单
    • 适用场景:Java 单体应用调试
    • 缺点:性能差,体积大,仅限 Java
  • Kryo
    • 特点:高性能二进制,速度极快,体积小
    • 适用场景:高并发、低延迟场景
    • 缺点:API 复杂,需注册类
  • Protobuf(推荐)
    • 特点:Google 出品,高效跨语言,可扩展
    • 适用场景:微服务跨语言通信
    • 缺点:需预定义。proto 文件
  • FST
    • 特点:类似 Kryo,高性能二进制
    • 适用场景:替代 Hessian 的高性能需求
    • 缺点:兼容性较弱

钝悟...大约 45 分钟分布式分布式通信RPC分布式通信RPC微服务Dubbo面试
《Dubbo 源码解读与实战》笔记

《Dubbo 源码解读与实战》笔记

开篇词 深入掌握 Dubbo 原理与实现,提升你的职场竞争力

Apache Dubbo是一款高性能、轻量级的开源 Java RPC 框架,它提供了三大核心能力:

  • 面向接口的远程方法调用;
  • 可靠、智能的容错和负载均衡;
  • 服务自动注册和发现能力。

Dubbo 是一个分布式服务框架,致力于提供高性能、透明化的 RPC 远程服务调用方案以及服务治理方案,以帮助我们解决微服务架构落地时的问题。


钝悟...大约 21 分钟笔记分布式分布式通信分布式分布式通信RPCDubbo
源码级深度理解 Java SPI

源码级深度理解 Java SPI

SPI 简介

SPI 全称 Service Provider Interface,是 Java 提供的,旨在由第三方实现或扩展的 API,它是一种用于动态加载服务的机制。Java 中 SPI 机制主要思想是将装配的控制权移到程序之外,在模块化设计中这个机制尤其重要,其核心思想就是 解耦

Java SPI 有四个要素:

  • SPI 接口:为服务提供者实现类约定的的接口或抽象类。
  • SPI 实现类:实际提供服务的实现类。
  • SPI 配置:Java SPI 机制约定的配置文件,提供查找服务实现类的逻辑。配置文件必须置于 META-INF/services 目录中,并且,文件名应与服务提供者接口的完全限定名保持一致。文件中的每一行都有一个实现服务类的详细信息,同样是服务提供者类的完全限定名称。
  • ServiceLoader:Java SPI 的核心类,用于加载 SPI 实现类。 ServiceLoader 中有各种实用方法来获取特定实现、迭代它们或重新加载服务。

钝悟...大约 25 分钟JavaJavaCore高级特性JavaJavaCoreSPIDubboSpring Bootcommon-loggingJDBC
Spring集成Dubbo

Spring 集成 Dubbo

ZooKeeper

ZooKeeper 可以作为 Dubbo 的注册中心。

Dubbo 未对 Zookeeper 服务器端做任何侵入修改,只需安装原生的 Zookeeper 服务器即可,所有注册中心逻辑适配都在调用 Zookeeper 客户端时完成。

安装

ZooKeeper 发布中心 选择需要的版本,下载后解压到本地。


钝悟...大约 4 分钟Java框架SpringSpring集成Java框架Spring集成Dubbo