【架构-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 处进行安全认证等操作。
相关推荐
一尘之中34 分钟前
【架构人生】一种“低耦合、高内聚”的处世哲学
架构·ai写作
Ryan今天学习了吗6 小时前
💥不说废话,带你上手使用 qiankun 微前端并深入理解原理!
前端·javascript·架构
Xの哲學7 小时前
Linux eMMC子系统深度解析:从硬件协议到内核实现
linux·网络·算法·架构·边缘计算
小马哥编程7 小时前
【软考架构】案例分析-瘦客户端C/S架构
运维·服务器·架构
二宝1529 小时前
黑马商城day8-ES01
分布式·微服务·架构
深度学习机器12 小时前
RAG的另一种思路,基于文档树结构的推理型检索
人工智能·算法·架构
unable code12 小时前
攻防世界-Misc-pdf
网络安全·ctf·misc·1024程序员节
深度学习机器12 小时前
Agent架构新方向?Claude Skills工作原理解析
人工智能·算法·架构
Wang's Blog13 小时前
Nestjs框架: gRPC微服务通信及安全实践全解析
安全·微服务·架构·nestjs
常先森13 小时前
【解密源码】 RAGFlow 切分最佳实践- naive parser 语义切块(pdf 篇)
架构·llm·agent