Apache Dubbo (RPC框架)

devtools/2024/11/7 0:17:45/

本文参考官方文档:Apache Dubbo

1. Dubbo 简介与核心功能

        Apache Dubbo 是一个高性能、轻量级的开源Java RPC框架,用于快速开发高性能的服务。它提供了服务的注册、发现、调用、监控等核心功能,以及负载均衡、流量控制、服务降级等高级功能。Dubbo 支持多种协议,包括但不限于 Dubbo 协议、RMI、HTTP、Hessian等,使得开发者可以灵活选择适合自己业务场景的通信协议。

具体功能点描述:

1.1 服务治理

  • 地址发现:Dubbo 提供了高性能的服务发现机制,支持大规模集群,并且可以与多种注册中心(如 Nacos、Zookeeper、Consul)进行适配。

  • 负载均衡:Dubbo 默认提供了多种负载均衡策略,包括加权随机、加权轮询、最少活跃请求数优先等。

  • 流量路由:Dubbo 支持基于规则的流量路由,可以实现 A/B 测试、金丝雀发布等功能。

1.2 流量管控

  • Dubbo 提供了丰富的流量管控规则,可以控制服务间的流量走向和 API 调用,实现动态调整服务行为如超时时间、重试次数、限流参数等。

1.3 微服务生态

  • 围绕 Dubbo 构建了完善的微服务治理生态,对于绝大多数服务治理需求,通过简单几行配置即可开启。

1.4 可视化控制台

  • Dubbo Admin 提供了可视化的 Web 交互控制台,可以实时监测集群流量、服务部署状态、排查诊断问题。

1.5 安全体系

  • Dubbo 支持基于 TLS 的数据传输通道,并提供认证、鉴权策略,实现细粒度的资源访问控制。

1.6 服务网格

  • 基于 Dubbo 开发的服务可以透明地接入 Istio 等服务网格体系,支持基于 Envoy 的流量拦截方式,也支持 Proxyless Mesh 部署模式。

1.7 高性能通信协议

  • Dubbo 提供了高性能的通信协议实现,支持流式通信模型,不绑定序列化协议,支持单个服务的多协议暴露。

1.8 云原生支持

  • Dubbo 完全遵循云原生微服务开发理念,支持 Kubernetes、Service Mesh 等云原生基础设施与部署架构。

1.9 易用性提升

  • Dubbo 官网大改版体现了对易用性体验的深刻理解和不懈追求,通过简化信息获取、优化内容结构和提升用户交互,为开发者创造一个更加友好和高效的开发环境。

2. Dubbo 的开源故事与发展历程

        Dubbo 最初由阿里巴巴开发,用于解决大规模服务化架构下的远程服务调用问题。随着其在业界的广泛应用,Dubbo 在2017年被捐献给 Apache 软件基金会,并在2018年成为 Apache 的顶级项目。Dubbo 的开源之路,不仅推动了微服务架构在国内的发展,也促进了开源社区的繁荣。

3. Dubbo 在云原生时代的演进

        随着云原生技术的兴起,Dubbo 也在不断进化。Dubbo3 作为新一代的微服务框架,提供了对云原生架构的全面支持,包括对 Kubernetes 的集成、服务网格(Service Mesh)的适配等。Dubbo3 通过 Proxyless Mesh 架构,减少了对 Sidecar 的依赖,降低了资源消耗,提高了性能。

4. 用户案例与实践

        Dubbo 在阿里巴巴、京东、滴滴等大型互联网公司中得到了广泛应用。例如,在阿里巴巴内部,Dubbo3 已经成为统一的服务框架,支撑着数以万计的服务实例。这些实践证明了 Dubbo 在处理高并发、高可用性场景下的强大能力。

5. Dubbo 架构详解

Dubbo 的架构包括以下几个核心组件:

  • Provider:服务提供者。

  • Consumer:服务消费者。

  • Registry:服务注册中心,如 Zookeeper、Nacos。

  • Monitor:服务监控中心,用于统计服务调用次数和时间。

  • Container:服务容器,用于运行服务提供者。

Dubbo 的调用关系遵循发起请求、服务注册、服务发现、服务调用、结果返回的流程。

6. Dubbo3 核心特性与升级

Dubbo3 引入了以下核心特性:

  • 全面支持异步调用:提高了服务调用的性能。

  • 增强的多语言支持:通过 gRPC 协议,Dubbo3 支持了更多的编程语言。

  • 服务网格集成:Dubbo3 可以与 Istio 等服务网格框架集成,提供更灵活的流量管理。

7. 快速入门与案例

        Dubbo 提供了简单的入门指南,开发者可以通过 Maven 依赖快速开始一个 Dubbo 项目。以下是一个简单的服务提供者和消费者的示例代码,以及必要的配置文件。

// 服务接口
public interface GreetingService {String sayHello(String name);
}// 服务提供者实现
@DubboService(version = "1.0.0")
public class GreetingServiceImpl implements GreetingService {public String sayHello(String name) {return "Hello " + name;}
}// 服务消费者调用
@DubboReference(version = "1.0.0")
private GreetingService greetingService;public String useGreetingService(String name) {return greetingService.sayHello(name);
}

不积跬步,无以至千里 --- xiaokai


http://www.ppmy.cn/devtools/131874.html

相关文章

【MySQL】深度学习与解析 : 库的操作知识整合

前言:本节内容是MySQL库的操作, 内容较少, 大体内容为创建库、删除库、修改库、库备份操作。 ps:本节内容适合安装了MySQL的友友们进行观看, 实操更有利于记住哦。 目录 创建数据库 查看数据库列表 创建数据库 删除数据库 …

Array.prototype.push()的理解和手写

1.Array.prototype.push()的用法 Array.prototype.push() 方法用于向数组的末尾添加一个或多个元素,并返回修改后数组的新长度。该方法会直接修改原始数组,而不是创建一个新的数组副本。 以下是 Array.prototype.push() 方法的用法: var ar…

Oracle OCP认证考试考点详解082系列13

题记: 本系列主要讲解Oracle OCP认证考试考点(题目),适用于19C/21C,跟着学OCP考试必过。 61. 第61题: 题目 解析及答案: 关于数据库链接,以下哪项陈述是正确的? A. 在一个数据库中…

多模态PaliGemma——Google推出的基于SigLIP和Gemma的视觉语言模型

前言 本文怎么来的呢?其实很简单,源于上一篇文章《π0——用于通用机器人控制的流匹配VLA模型:一套框架控制7种机械臂(改造了PaliGemma和ACT的3B模型)》中的π0用到了PaliGemma 故本文便来解读下这个PaliGemma 第一部分 PaliGemma 1.1 Pal…

软件设计师 7日速成

数据流图和数据字典 数据流图 定义 数据流图是一种图形化的工具,用于描述系统中数据的流动情况。它可以帮助我们可视化数据在系统中的处理过程,包括数据的来源、去向、存储位置以及处理方式。 组成元素 数据流图通常包含以下四个基本元素&#xff1…

ML 系列:机器学习和深度学习的深层次总结( 19)— PMF、PDF、平均值、方差、标准差

一、说明 在概率和统计学中,了解结果是如何量化的至关重要。概率质量函数 (PMF) 和概率密度函数 (PDF) 是实现此目的的基本工具,每个函数都提供不同类型的数据:离散和连续数据。 二、PMF 的定义…

智会智展,活动必备

智会智展 APP 各大应用市场均可下载统一链接https://m.malink.cn/s/r6nQVf

【Excel】区域单元格选择(一)

目录 一、无空白区域选择 方式一 方式二 二、有空白区域选择 三、选择指定单元格区域 一、无空白区域选择 方式一 ctrl shift ↓ 方式二 ctrl a 二、有空白区域选择 第一步:先ctrl shift ↓ 选择第一片区域 第二步:再ctrl鼠标左键点击选中…