Dubbo

本文详细介绍了Dubbo的概念、核心组件、配置选项、集群容错方案和负载均衡策略。Dubbo作为高性能的RPC框架,提供了透明化的远程方法调用、自动注册与发现等功能。同时,它支持多种负载均衡策略,如随机、轮询等。相较于SpringCloud,Dubbo在带宽使用和注册中心选择上有其独特优势。此外,文章还对比了两者在应用场景和技术特点上的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Dubbo

概念

Dubbo是阿里巴巴旗下的基于java的高性能RPC分布式框架。核心组件包括:

  • 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

  • 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

  • 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

作用

  • 透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。

  • 负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。

  • 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。
    采用全spring配置方式,透明化接入应用,只需要简单的配置,对于应用没用任何API的入侵,用spring加载dubbo的配置即可

dubbo内置容器

  1. Spring Container
  2. Jetty Container
  3. Log4j Container

核心配置

配置配置说明
dubbo:service服务配置
dubbo:reference引用配置
dubbo:protocol协议配置
dubbo:application应用配置
dubbo:module模块配置
dubbo:registry注册中心配置
dubbo:monitor监控中心配置
dubbo:provider提供方配置
dubbo:consumer消费方配置
dubbo:method方法配置
dubbo:argument参数配置

集群容错方案

集群容错方案说明
Failover Cluster失败自动切换,自动重试其他服务器 (默认)
Failfast Cluster快速失败,立即报错,只发起一次调用
Failsafe Cluster失败安全,出现异常时,直接忽略
Failback Cluster失败自动恢复,记录失败请求,定时重发
Forking Cluster并行调用多个服务器,只要一个成功返回即可
Broadcast Cluster广播逐个调用所有提供者,任意一个报错即报错

负载均衡策略

负载均衡策略说明
Random LoadBalance随机,按权重设置随机概率
RoundRobin LoadBalance轮询,按公约后的权重设置轮询比率
LeastActive LoadBalance最少活跃调用,相同活跃数的随机
ConsistentHash LoadBalance一致性Hash,相同参数的请求总是发到同一个提供者

通信框架

默认使用Netty框架,集成有Mina、Grizzly

Dubbo与SpringCloud

Dubbo优势:

  • 单一应用架构:系统压力小时,一个应用就可以将所有功能部署在一起,节省成本,部署节点少
  • 垂直应用架构:访问量大时,将应用拆开,提升效率
  • 分布式服务架构:垂直应用增加时,将核心业务抽取出来独立,形成稳定的服务中心。

SpringCloud优势:

  • 开箱即用,快速启动
  • 使用与各种复杂场景
  • 轻量级的丰富组件,功能齐全
  • 约定优于配置

比较:

  1. Dubbo使用二进制传输,占用的带宽更少。
  2. SpringCloud使用http传输,带宽消耗较大。
  3. Dubbo的jar包依赖处理起来很麻烦
  4. Dubbo的注册中心可选zk,redis等,SpringCloud的注册中心只能是eureka或者自研
  5. SpringCloud的接口协议约定比较自由,需限制接口无序升级
### Apache Dubbo 微服务框架使用指南 Apache Dubbo 是一种高性能的 Java 基础设施,专注于微服务之间的高效通信和服务治理。以下是关于 Dubbo 的一些关键特性和常见问题解答。 #### 1. Dubbo 核心组件及其作用 Dubbo 提供了一系列的核心功能来支持微服务架构下的开发和运行: - **RPC 调用**: Dubbo 实现了远程过程调用 (Remote Procedure Call),使客户端能够像调用本地方法一样访问远端服务器的方法[^4]。 - **服务注册与发现**: 利用 Zookeeper 或 Nacos 等工具实现服务的动态注册与发现,从而减少硬编码依赖并提升系统的灵活性[^3]。 - **负载均衡**: 支持多种负载均衡算法(如随机、轮询),以优化资源利用并增强系统稳定性[^4]。 - **容错处理**: 集成有完善的错误恢复机制,比如失败重试、超时控制等,保障即使在网络波动情况下也能维持正常运作[^3]。 #### 2. 安装与基本配置流程 要开始使用 Dubbo 构建自己的微服务体系,需完成以下几个主要步骤: ##### a) 环境搭建 确保 JDK 版本满足最低要求,并下载最新版本的 Dubbo 及其相关依赖库文件。 ##### b) 创建 Maven 工程结构 定义好项目的 pom.xml 文件内容,引入必要的依赖项,例如 spring-boot-starter-dubbo 和 hessian-lite 等[^4]。 ```xml <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.x.x</version> </dependency> ``` ##### c) 编写 Provider/Consumer 接口及其实现类 按照约定俗成的方式分别编写服务提供方(Service Provider Interface, SPI)以及消费方(Client Side Stub), 并通过 @Service/@Reference 注解标注它们的关系[^1]。 ```java // Service interface definition public interface DemoService { String sayHello(String name); } // Implementation of the service on provider side. @Service(version = "1.0.0") public class DemoServiceImpl implements DemoService{ public String sayHello(String name){ return "Hello,"+name; } } ``` 对于消费者而言,则只需声明引用即可获得对应实例对象。 ```java @Reference(version="1.0.0") private DemoService demoService; @Test public void testSayHello(){ System.out.println(demoService.sayHello("world")); } ``` #### 3. 解决 Dubbo 中常见的几个疑问点 - Q: 如果我的项目里既有 RESTful API又有 Dubbo RPC 怎么办? A: 这两种风格完全可以共存于同一个工程之中,只需要区分清楚各自的职责范围就可以了。REST 更适合外部暴露给第三方使用的开放接口;而内部紧密耦合的部分则推荐采用更高效的二进制形式传输——即 Dubbo 所擅长之处[^4]。 - Q: 我们现在正在考虑从传统单体应用迁移到基于 Dubbo 的微服务平台上来,请问有哪些注意事项吗? A: 在迁移过程中需要注意以下几点事项:一是评估现有业务逻辑是否具备拆分的可能性;二是提前规划好新旧两套体系间的过渡方案;三是充分测试各个子模块独立部署后的表现情况,最后再逐步替换掉原有的部分直至完全切换完毕为止[^2]. ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值