远程调用 Dubbo 与 Feign 的区别

欢迎大家关注我的公众号【老周聊架构】,Java后端主流技术栈的原理、源码分析、架构以及各种互联网高并发、高性能、高可用的解决方案。

一、相同点

Dubbo 与 Feign 都依赖注册中心、负载均衡。

二、区别

1、协议

Dubbo:

  • 支持多传输协议(Dubbo、Rmi、http、redis等等),可以根据业务场景选择最佳的方式。非常灵活。
  • 默认的Dubbo协议:利用NettyTCP传输,单一、异步、长连接,适合数据量小、高并发和服务提供者远远少于消费者的场景。

Feign:

基于Http传输协议,短连接,不适合高并发的访问。

2、负载均衡

Dubbo:

  • 支持4种算法(随机、轮询、活跃度、Hash一致性),而且算法里面引入权重的概念。
  • 配置的形式不仅支持代码配置,还支持Dubbo控制台灵活动态配置。
  • 负载均衡的算法可以精准到某个服务接口的某个方法。

Feign:

  • 只支持N种策略:轮询、随机、ResponseTime加权。
  • 负载均衡算法是Client级别的。

3、容错策略

Dubbo:

支持多种容错策略:failover、failfast、brodecast、forking等,也引入了retry次数、timeout等配置参数。

Feign:

利用熔断机制来实现容错的,处理的方式不一样。

  • 29
    点赞
  • 169
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 15
    评论
Spring Cloud是一组用于构建分布式系统的开源框架,它为我们提供了一种轻量级的微服务架构的解决方案。而Dubbo是阿里巴巴开源的高性能RPC框架,用于构建分布式服务框架。而Feign是Spring Cloud提供的一种声明式的Web服务客户端,它可以与Dubbo进行集成,提供更加便捷的服务调用方式。 在集成DubboFeign之前,我们需要先将Dubbo注册到Spring Cloud的注册中心,使得Dubbo服务可以被Spring Cloud所管理。这样,我们就可以使用Feign作为Spring Cloud中的服务消费者来调用Dubbo提供的服务。通过Feign,我们可以避免编写繁琐的服务调用代码,只需要简单的声明式接口,并使用注解来定义具体的服务调用方法,Feign会动态生成代理实现类,自动处理服务调用的细节。 在使用Feign集成Dubbo时,我们需要在Spring Boot配置文件中进行相应的配置,声明需要调用的Dubbo服务接口。然后,通过在代码中定义Feign的接口,使用注解来标识调用的Dubbo服务地址、服务方法等。当我们调用该接口时,Feign会自动发起对Dubbo服务的远程调用。 通过将FeignDubbo集成,我们可以通过Spring Cloud的整体架构来统一管理和调用Dubbo的服务,简化了代码编写和服务调用的过程。同时,Feign还具有负载均衡、容错等一系列特性,可以进一步提高系统的稳定性和可靠性。 综上所述,通过集成DubboFeign,我们可以更加方便地在Spring Cloud中调用和管理Dubbo的服务,提高系统的可维护性和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老周聊架构

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值