【架构-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 处进行安全认证等操作。
相关推荐
Xxtaoaooo1 小时前
原生多模态AI架构:统一训练与跨模态推理的系统实现与性能优化
人工智能·架构·分布式训练·多模态·模型优化
洛卡卡了1 小时前
从被动救火到主动预警,接入 Prometheus + Grafana 全流程
后端·面试·架构
失散131 小时前
分布式专题——44 ElasticSearch安装
java·分布式·elasticsearch·架构
怿星科技1 小时前
Android MVVM架构解析:现代开发的首选模式
android·架构
文火冰糖的硅基工坊2 小时前
[嵌入式系统-100]:IoT(物联网)与AIoT(人工智能物联网)
人工智能·物联网·架构·创业
fakerth2 小时前
【OpenHarmony】分布式文件服务模块架构
分布式·架构·操作系统·openharmony
会跑的葫芦怪2 小时前
RocketMQ 与 RabbitMQ 全面对比:架构、性能与适用场景解析
架构·rabbitmq·rocketmq
zandy10114 小时前
HENGSHI SENSE异构过滤架构:基于三层执行引擎的跨源联邦查询性能优化实践
性能优化·架构·agentic bi·异构结构
brzhang5 小时前
我用 Flutter 做了个小游戏,结果发现这玩意有点意思
前端·后端·架构
用户6387994773055 小时前
我把我的 monorepo 迁移到 Bun,这是我的真实反馈
javascript·架构