Nginx和Ribbon的区别

前言

程序员阿亮今天发现有的Nginx和Ribbon都有负载均衡的功能,不过Nginx和Ribbon实际上都有这个功能但是还是有区别的。

一、Nginx是什么?

总所周知,Nginx是一个集高性能的 HTTP服务器反向代理服务器,同时也支持负载均衡、缓存等功能的工具

  1. Web服务器(静态资源服务)

server {

listen 80;

server_name example.com;

location / {

root /var/www/html;

index index.html;

}

}

  1. 反向代理

location /api/ {

proxy_pass http://backend-server;

}

  1. 负载均衡(服务端负载均衡)

upstream backend {

server 192.168.1.10:8080;

server 192.168.1.11:8080;

server 192.168.1.12:8080;

}

可以做静态资源服务器,可以反向代理,又可以负载均衡

它的负载均衡是服务端负载均衡,也就是我们的请求会先到Nginx服务器,然后再通过这个Nginx服务器负载均衡转发到服务器节点中。

二、Ribbon是什么?

相比于Nginx,Ribbon的功能更纯粹,它是一个是 Netflix 开源的 客户端负载均衡器 ,作为Java库集成在应用程序中,主要用于微服务架构中的服务间调用

注意的是这个客户端指的是我们应用程序,不是用户的客户端。

三、俩者区别

对于Nginx,负载均衡只是它的功能之一,而Ribbon则主要是为了负载均衡设计的。Ribbon主要用于应用程序中服务间的调用,如微服务A调用微服务B,对微服务B的集群的负载均衡。

而Nginx则是服务端负载均衡,用于对服务器集群进行负载均衡

场景1:对外API网关

用户浏览器 → Nginx(负载均衡) → [微服务集群]

场景2:静态资源服务

用户请求 → Nginx(直接返回静态文件)

场景3:SSL终止

HTTPS请求 → Nginx(解密) → HTTP转发到后端

实际上,大部份场景都是俩者兼用

我们可以做Gateway集群,然后用Nginx进行负载均衡,再在Gateway使用Ribbon进行负载均衡

/分层负载均衡架构

用户请求

Nginx(对外负载均衡,高并发入口)

Gateway(API网关)

Ribbon(内部负载均衡,调用业务微服务)

订单服务\] → Ribbon → \[用户服务集群

库存服务\] → Ribbon → \[商品服务集群

四、总结

Nginx和Ribbon都是负载均衡解决方案,但它们的定位和工作方式完全不同。

首先从定位上说,Nginx是服务端负载均衡器,作为独立的中间件部署;Ribbon是客户端负载均衡器,作为库集成在应用中。

从工作原理看,Nginx是客户端请求先到Nginx,由Nginx转发到后端服务,多了一跳网络;而Ribbon是客户端直接维护服务实例列表,自己选择目标服务发起请求,减少了一跳。

从性能角度,Nginx用C语言编写,性能极高,适合高并发场景;Ribbon运行在JVM中,性能相对较低,但灵活性更好。

从适用场景,在我们项目中,对外暴露的API我们用Nginx做网关和负载均衡,微服务内部调用则用Ribbon,这样既能保证对外的高性能,又能实现内部调用的灵活性。

另外补充一点,Ribbon通常与Eureka等服务注册中心配合使用,能够自动感知服务实例的变化;而Nginx需要手动配置或通过第三方工具动态更新配置

相关推荐
Maiko Star13 小时前
* SpringBoot整合LangChain4j
java·spring boot·后端·langchain4j
明月_清风13 小时前
Go语言空接口与类型断言完全指南:从"万能容器"到"类型还原"
后端·go
每天进步一点_JL14 小时前
Spring Boot 缓存体系
后端
百珏14 小时前
[灰度发布]:全链路透传组件:APM、自研方案与 Java Agent 的实现取舍
后端·设计模式·架构
正在走向自律14 小时前
DISTINCT 去重查询为什么这么慢?聊聊我能理解的几种优化思路
后端
OpsEye14 小时前
数据库连接池爆了,这3个命令能救你一次
运维·数据库·后端
绝知此事14 小时前
【产品更名】通义灵码升级为 Qoder CN:AI 编码助手新时代,附大模型收费与 Spring Boot 支持全对比
人工智能·spring boot·后端·idea·ai编程
~|Bernard|14 小时前
GO语言中哪些类型是可比较类型的(==和!=)
开发语言·后端·golang
用户67570498850215 小时前
Celery 太重了?这可能是你一直在找的 asyncio 任务队列
后端·python·消息队列
Cloud_Shy61815 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)
前端·后端·python·数据分析·excel