【架构-33】Ribbon、Nginx、Gateway之间的区别和联系

Ribbon

  1. 功能侧重:主要用于客户端的负载均衡。它是一个基于客户端的软件工具,在微服务架构中,帮助服务消费者(如一个微服务)去调用多个服务提供者(如其他微服务)时,能以某种负载均衡策略(如轮询、随机等)选择合适的服务提供者实例进行调用,从而实现服务调用的负载均衡。
  2. 使用场景:在微服务体系内部,当一个微服务需要调用其他多个相同功能的微服务时,Ribbon 能有效分配请求流量,提高系统的整体可用性和性能。例如,一个订单服务微服务需要调用多个库存服务微服务来查询库存信息,Ribbon 可以平衡这些请求到不同的库存服务微服务实例上。

Nginx

  1. 功能侧重:是一款高性能的反向代理服务器,也能用于负载均衡和 HTTP 服务器。作为反向代理,它接收来自外部网络的请求,将请求转发到内部网络中的真实服务器上,对客户端隐藏后端服务器的真实信息。在负载均衡方面,它可以将请求按照设定的策略(如轮询、IP 哈希等)均匀地分配到后端的多个服务器上,同时还能对静态资源进行高效的处理。
  2. 使用场景:在服务器的前端,作为接入层服务器,将外部请求转发到内部服务器集群。比如在网站架构中,将用户对网站的请求转发到后端的 Web 服务器或者应用服务器上,还可以用于处理大量的并发静态资源请求,减轻后端服务器的压力。

Gateway(Spring Cloud Gateway)

  1. 功能侧重:是一种基于 Spring 生态的网关服务,专注于 API 网关功能。它提供了路由、断言、过滤等功能。可以根据请求的路径、方法、头部等条件(断言)将请求路由到不同的后端服务,并且在请求传递过程中可以对请求和响应进行各种处理(过滤),如权限验证、请求日志记录等。
  2. 使用场景:在微服务架构中作为 API 网关,管理所有外部请求进入微服务系统的入口,对微服务进行统一的管理和保护。例如,外部客户端请求微服务系统中的某个服务,先经过 Gateway,由 Gateway 根据请求的特点决定将请求转发到哪个具体的微服务,同时可以在 Gateway 处进行安全认证等操作。
相关推荐
ZhengEnCi17 小时前
Q01-高并发点赞系统架构设计
架构
笨鸟飞不快20 小时前
从 MVC 到 DDD:一次真实的渐进式迁移实录
后端·架构
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
锋行天下2 天前
我试图优化 Vite 的拆包,结果首屏慢了 10 倍
前端·vue.js·架构
小鼻子的猫2 天前
独立开发 30 天:2.5 万行代码,23 个 Bug,5 次重构——一个 AI 社区的诞生
架构
咖啡八杯2 天前
GoF设计模式——命令模式
java·设计模式·架构
candyTong2 天前
阿里开源 AI Code Review 工具:ocr review 的执行链路解析
javascript·后端·架构
doiito3 天前
【Agent Harness】TPS的“自工程完结”教会了我一件事:别把Bug留给下一道工序
架构·rust
烬羽3 天前
中英文 token 数量差一倍?两段 JS 代码搞懂 LLM 底层是怎么"读"文字的
javascript·程序员·架构