news 2026/6/10 8:35:46

关于dubbo这个技术栈

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
关于dubbo这个技术栈

来研究一下dubbo,看一下对于dubbo我们需要掌握什么。

1.对于最主要的功能了解阶段,它是干啥的:

所谓的dubbo,给她做一个定义,就是,它是一个依赖,让几个springboot之间的通讯,可以配置一下,不在使用http协议,去进行交互。而是使用dubbo自带的协议。http协议就是,建立tcp连接,然后http请求包,发送,发送完以后断了。而dubbo就是,一直连接着tcp请求,然后一直发送http请求包。

2.对于内部拓扑结构的把握

这里主体,所谓的dubbo就是一个依赖,作用于两个客体,一个是springboot,一个是注册中心。
只要在springboot上配置好了,
就可以,轻松使用另一个springboot里面的service。

3.对于技术栈配置与使用阶段

对于注册中心的操作

对于一个springboot的配置(生产者+消费者)

3.对于dubbo的消费的一个最小的demo

4.对于dubbo生产级配置。

你的总结很不错!Dubbo 的核心理解确实如此。我们来系统化地整理一下 Dubbo 需要掌握的知识点,以便于学习和面试。


一、Dubbo 是什么(核心定义)

Apache Dubbo是一款高性能、轻量级的Java RPC 框架,主要用于解决分布式系统中服务之间的通信问题。

关键点

  • RPC(Remote Procedure Call):让远程调用像本地调用一样简单透明。
  • 通信方式:它不仅仅“替换 HTTP”,而是提供了一套基于 TCP 的私有协议(Dubbo 协议),相比 HTTP 有更好的性能(长连接、二进制编码、更少的头部开销)。
  • 核心功能:服务治理、负载均衡、服务降级、流量控制等。

与你的理解的补充
你提到的“一直连接着 TCP 请求”是对的,这是连接复用,避免了 HTTP 的“三次握手”开销。但传输的并不是“HTTP 请求包”,而是Dubbo 自定义的二进制协议帧


二、核心架构与角色(拓扑结构)

Dubbo 经典架构包含三种角色:

  1. Provider(服务提供者):暴露服务的 Spring Boot 应用。
  2. Consumer(服务消费者):调用远程服务的 Spring Boot 应用。
  3. Registry(注册中心):服务的注册与发现中心。常用:Zookeeper、Nacos、Redis。

工作流程

  1. Provider 启动,向 Registry 注册自己提供的服务。
  2. Consumer 启动,向 Registry 订阅所需服务,并获取 Provider 地址列表。
  3. Consumer 根据负载均衡策略,选择一个 Provider 进行RPC 调用
  4. 监控中心(可选)会统计调用次数和调用时间。

三、技术栈配置与使用(核心技能)

1. 注册中心配置(以 Nacos 为例)

依赖

<dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><version>${dubbo.version}</version></dependency>

配置(application.yaml):

dubbo:registry:address:nacos://localhost:8848

2. 服务提供者(Provider)配置

步骤

  1. 定义服务接口(API 模块,需共享给消费者):
    packagecom.example.api;publicinterfaceUserService{UsergetUser(Longid);}
  2. 实现接口(Provider 模块):
    @DubboService// 关键注解,声明暴露 Dubbo 服务publicclassUserServiceImplimplementsUserService{// 实现方法}
  3. 配置(application.yaml):
    dubbo:application:name:user-service-providerprotocol:name:dubboport:20880# Dubbo 协议端口scan:base-packages:com.example.provider.service# 扫描 DubboService
  4. 启动 Spring Boot 应用。

3. 服务消费者(Consumer)配置

步骤

  1. 引入相同的 API 接口 Jar 包
  2. 注入并调用远程服务
    @RestControllerpublicclassOrderController{@DubboReference// 关键注解,引用远程服务privateUserServiceuserService;@GetMapping("/order")publicOrdergetOrder(){Useruser=userService.getUser(123L);// 像调用本地方法一样// ... 业务逻辑}}
  3. 配置(application.yaml):
    dubbo:application:name:order-service-consumerregistry:address:nacos://localhost:8848
  4. 启动 Spring Boot 应用并访问接口,即完成远程调用。

四、生产级配置要点

  1. 负载均衡

    @DubboReference(loadbalance = "roundrobin") // 轮询

    策略:random(默认)、roundrobinleastactiveconsistenthash

  2. 集群容错

    @DubboReference(cluster = "failover")

    模式:failover(失败重试,默认)、failfast(快速失败)、failsafe(安全失败)、failback(自动恢复)、forking(并行调用)。

  3. 超时与重试

    @DubboReference(timeout = 3000,retries = 2)
    • timeout:调用超时时间(毫秒)。
    • retries:失败重试次数(不含第一次)。
  4. 服务降级

    • 通过mock属性实现。当服务不可用时,返回一个本地 Mock 数据,保证主流程可用。
    @DubboReference(mock="com.example.service.UserServiceMock")
  5. 多版本与分组

    • 版本:用于灰度发布、接口不兼容升级。
    • 分组:用于服务隔离(如:测试环境、生产环境)。
    @DubboReference(version="2.0.0",group="test")
  6. 线程模型与协议优化

    • 调整 Dubbo 协议端口、线程池大小等。
    • 考虑使用tri协议(基于 gRPC,支持 HTTP/2),便于跨语言和穿透网关。

五、最小 Demo 思路

  1. 创建一个Maven 父工程
  2. 创建api 子模块:定义UserService接口。
  3. 创建provider 子模块
    • 依赖 api 模块。
    • 实现UserServiceImpl,使用@DubboService
    • 配置注册中心(如 Nacos)和 Dubbo 协议。
  4. 创建consumer 子模块
    • 依赖 api 模块。
    • 在 Controller 中使用@DubboReference注入UserService
    • 配置注册中心。
  5. 启动Nacos
  6. 依次启动providerconsumer
  7. 访问 consumer 的接口,验证调用成功。

总结:需要掌握的知识图谱

类别具体内容
核心概念RPC、服务治理、注册中心、Provider、Consumer
架构服务注册与发现流程、调用流程、集群容错模式
配置开发@DubboService@DubboReference、配置文件
高级特性负载均衡、服务降级、多版本/分组、超时重试
生产实践线程模型优化、监控(Dubbo Admin)、链路追踪集成
源码理解SPI 机制(Dubbo 扩展的基石)、服务暴露与引用流程

从你已有的理解出发,按照这个脉络去深入学习和实践,就能系统性地掌握 Dubbo。建议在理解基本配置后,动手搭建一个完整的 Dubbo 微服务 demo,并尝试配置不同的负载均衡、容错策略,观察其效果。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/8 17:44:29

卡尔曼滤波算法实战应用案例分享

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个卡尔曼滤波算法实战项目&#xff0c;包含完整的功能实现和部署方案。点击项目生成按钮&#xff0c;等待项目生成完整后预览效果 今天想和大家分享一个特别实用的技术——卡…

作者头像 李华
网站建设 2026/6/1 2:02:19

VibeVoice能否生成车载导航语音?智能交通系统接入

VibeVoice能否生成车载导航语音&#xff1f;智能交通系统接入 在一辆自动驾驶测试车上&#xff0c;驾驶员正通过语音与座舱助手交流&#xff1a;“前面路口怎么走&#xff1f;” “右转进入辅路&#xff0c;注意避让非机动车。”助手回应道&#xff0c;语气平稳、节奏自然&…

作者头像 李华
网站建设 2026/5/29 23:22:55

哈夫曼编码在实时视频传输中的实战应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个视频帧压缩演示系统&#xff0c;要求&#xff1a;1. 实现基于哈夫曼编码的视频帧压缩算法 2. 支持实时摄像头输入和视频文件处理 3. 显示原始帧和压缩帧的对比 4. 统计压缩…

作者头像 李华
网站建设 2026/6/2 1:07:54

PCIe-Message Request Rules(一)

Gen5规范定义了以下11 中Message 类型: 1. INTx Interrupt Signaling(INTx 中断信号) 使用场合:旧式中断仿真 说明:为了兼容不支持 MSI(Message Signaled Interrupts)的旧设备和软件,PCIe 使用 Message TLP 来模拟传统的 INTx(INT A/B/C/D)中断线信号。当设备需要发…

作者头像 李华
网站建设 2026/6/5 16:54:13

解锁跨平台游戏模组:这款免费工具让你轻松获取任意平台模组

解锁跨平台游戏模组&#xff1a;这款免费工具让你轻松获取任意平台模组 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 还在为Epic Games Store或GOG平台购买的游戏无法使用Ste…

作者头像 李华
网站建设 2026/6/9 19:49:19

通信协议仿真:TCP_IP协议栈仿真_(1).TCP-IP协议栈概述

TCP/IP协议栈概述 1. 引言 TCP/IP协议栈是互联网通信的基础&#xff0c;它定义了一套规则和标准&#xff0c;使不同类型的网络设备和应用程序能够相互通信。TCP/IP协议栈不仅包括传输控制协议&#xff08;TCP&#xff09;和互联网协议&#xff08;IP&#xff09;&#xff0c;还…

作者头像 李华