Dubbo

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

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的接口协议约定比较自由,需限制接口无序升级
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值