当前位置: 首页 > news >正文

Ribbon和Feign客户端负载均衡及服务调用


#### 前言

什么时负载均衡?(Load balancing)负载均衡,是一种计算机技术,用来在多个计算机(计算机集群)、网络连接、CPU、磁盘驱动器或其他资源中分配负载,以达到最优化资源使用、最大化吞吐率、最小化响应时间、同时避免过载的目的。过去所说的负载均衡常指服务端的负载均衡,在客户端和服务器端之间增加负载均衡器来实现。那么,客户端负载均衡是什么?


![](https://i-blog.csdnimg.cn/blog_migrate/7a6b30c3aee2c3251e7a2d6f9b852945.png)


#### 客户端负载均衡

客户端负载均衡是相对服务端而言的,主要出现在微服务中,服务消费之间一种软负载均衡的实现方案。客户端本地维护了一个可用的服务注册列表,在每次请求之前通过一定的算法,从服务列表中选择一个服务,发送给服务器端来处理本次请求的策略。常见的客户端负载均衡SpringCloud的Ribbon与Feign实现。


#### Ribbon的简介

Ribbon是Netflix公司的开源项目,是一款基于http和TCP的客户端负载均衡组件,它是无法独立部署,一般以Spring Cloud Ribbon实现,基于轮询、随机、加权、地址hash等规则自动获取和调用服务。


Ribbon的几个核心组件:

- IClientConfig
- ServiceList
- ServiceListFilter
- IRule
- IPing
- ILoadBalancer
- ServiceListUpdater



![](https://i-blog.csdnimg.cn/blog_migrate/d3b0d036a458592c5d2823246948f9b5.png)

Ribbon的工作原理



#### Feign的简介

Spring Cloud的服务发现功能,除了可以用RestTemplate外,还可以用Feign客户端实现。Feign是一个声明式的Web Service客户端,通过在程序中使用注解@FeignClient 实现热插拔式动态代理创建客户端的效果,从而获取和调用目标地址和服务方法,处理本次请求。


工作过程:


- 建立与“服务提供者”的网络连接。
- 构造请求。
- 发送请求到“服务提供者”。
- 处理“服务提供者”返回的响应结果。



![](https://i-blog.csdnimg.cn/blog_migrate/7931022088bc3379fdce98711de13b84.png)

Feign工作原理



#### Ribbon和Feign的区别

- 启动类注解不同,Ribbon使用的注解是@RibbonClient,而Feign使用注解是@EnableFeignClients。
- 服务的指定位置不同,Ribbon的服务实在注解@RibbonClient中声明的,而Feign是在注解@FeignClient中声明的。
- 调用方式不同,Ribbon需要自己构建HTTP请求来,使用RestTemplate将该请求发送出去。Feign在Ribbon的基础上进行封装,采用的是接口的方式,无需自己构建HTTP请求,只需将其他服务的方法定义成抽象方法即可。
- 依赖不同,Ribbon的Maven依赖是Spring-starter-ribbon;Feign的Maven依赖是Spring-starter-openfeign。

总结,Ribbon使用了RestTemplate,其代码可读性、可维护性和开发体验一般;Feign性能强,灵活性好。


 


推荐相关阅读:FeignClient注解及参数问题


既然看完了整篇文章,不妨再关注公众号,获取更多精彩




![](https://i-blog.csdnimg.cn/blog_migrate/f3c868b436e90512b966823eeef45939.jpeg)

同名原创公众号: 
程序大视界

http://www.jsqmd.com/news/772281/

相关文章:

  • fastbook商业应用:AI项目商业化落地终极指南
  • 终极指南:Vue3后台管理系统状态管理进阶——复杂业务逻辑的优雅处理方案
  • YC - 35 背心无人 AI 工作站:服装生产的变革者,是噱头还是实力?
  • 别再为对账差异头疼了!SAP序时账导出避坑指南:BKPF/BSEG字段选择与凭证状态排除
  • 单体架构,分布式系统的差别在哪里?
  • 基于fortbot框架的Python量化交易机器人开发实战指南
  • SpringCloud分布式配置中心浅谈
  • 无名入库,有名成器,老子这句话放进 SAP HANA 开发里,是一套从混沌数据到可信模型的修炼法
  • 2026年5月苏州昆山发电机租赁最新排行榜:实测top4家出租服务商合规资质与服务对比 - 奋斗者888
  • 终极OpenVINO AI插件指南:30分钟让Audacity变身专业音频工作站
  • Next.js全栈开发最佳实践:从TypeScript到Tailwind CSS的完整工具链
  • 别再手动切换方向了!盘点ADI和TI那几款能自动换向的RS485芯片(附选型避坑指南)
  • 2026年线下相亲平台口碑排行分析:主流合规平台核心能力解析与适配指南 - 产业观察网
  • GCP Vertex AI代理搭建:无缝对接Anthropic客户端,实现零改造迁移
  • 分布式集群Session缓存丢失问题
  • BitRouter:为AI智能体构建高性能智能路由与安全代理层
  • 3分钟上手ChanlunX:零基础实现缠论自动化分析的终极方案
  • 超强项目脚手架Cookiecutter:告别重复代码编写的终极指南
  • Lime3DS游戏截图与录像功能:高质量游戏内容创作终极指南
  • 彻底搞懂最小生成树算法:从概念到实战的完整指南
  • **靠谱的餐饮线上营销怎么选2026指南,本地生活平台精准引流与私域复购率提升策略** - 品牌企业推荐师(官方)
  • Ripes终极指南:如何通过可视化仿真彻底掌握RISC-V处理器架构
  • 终极指南:electron-react-boilerplate架构设计揭秘,打造企业级跨平台桌面应用的最佳实践
  • 如何用MobileSAM与Inpaint-Anything实现高效图像修复:完整实战指南
  • SpringCloud+MyBatis(oracle)逆向工程自动生成代码
  • River时间序列预测终极指南:从Holt-Winters到SNARIMAX的完整教程
  • 2026深圳黄金回收避坑指南:认准这几家正规门店最放心 - 品牌企业推荐师(官方)
  • ComfyUI IPAdapter Plus终极实战:专业级多模型图像生成方案
  • 3分钟解锁Android TV遥控器新姿势:免费虚拟鼠标工具终极指南
  • 谱华检测|成都CMA权威第三方,用精准数据守护蓉城呼吸健康 - 品牌企业推荐师(官方)