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

【架构-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 处进行安全认证等操作。

http://www.kler.cn/a/368951.html

相关文章:

  • CSS 入门:美化网页的魔法
  • 详解varint,zigzag编码, 以及在Go标准库中的实现
  • maven之pom.xml文件解读
  • 1024——视触觉传感器GelSight的前世今生
  • 前端代码分享--爱心
  • 【无人机设计与控制】改进人工势场法,引入模糊控制实现无人机路径规划和避障
  • OCR应用之集装箱箱号自动识别技术,原理与应用
  • matlab逻辑与有两种表达
  • 深入浅出 C++ STL:解锁高效编程的秘密武器
  • vLLM推理部署Qwen2.5
  • C++学习路线(二十八)
  • 图---java---黑马
  • SELinux详解
  • 图像处理学习笔记-20241021
  • Spring Boot 应用开发全攻略:从入门到精通
  • python——文件存储与写入path
  • CentOS 7 上安装 MySQL 8.0 教程
  • Python入门——yield生成器和iter迭代器
  • 学习记录:js算法(七十六):一手顺子
  • Vue3 跨标签页或跨窗口通信
  • 负载均衡服务器攻击怎么解决最有效?
  • 解决电脑突然没有声音
  • simple_php
  • Flink 源码 TaskManagerRunner 启动 Akka Actor System 源码
  • JVM(HotSpot):GC之G1垃圾回收器
  • FPGA第 13 篇,使用 Xilinx Vivado 创建项目,点亮 LED 灯,Vivado 的基本使用(点亮ZYNQ-7010开发板的LED灯)