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需要手动配置或通过第三方工具动态更新配置

相关推荐
渣瓦攻城狮1 天前
互联网大厂Java面试:从数据库连接池到分布式缓存及微服务
java·redis·spring cloud·微服务·hikaricp·数据库连接池·分布式缓存
百锦再1 天前
Java中的日期时间API详解:从Date、Calendar到现代时间体系
java·开发语言·spring boot·struts·spring cloud·junit·kafka
等....1 天前
MobaXterm操作虚拟机
后端
笨蛋不要掉眼泪1 天前
Sentinel 流控规则详解:三种模式与三种效果实战指南
java·jvm·数据库·后端·sentinel
健康平安的活着1 天前
AI之Toolcalling的使用案例(langchain4j+springboot)
人工智能·spring boot·后端
PythonFun1 天前
HAProxy端口转发入门:从“搬砖工”到“智能交通警察”
服务器·后端·网络安全
Ama_tor1 天前
Flask |零基础进阶(上)
后端·python·flask
pyniu1 天前
Elasticsearch学习
后端·学习·elasticsearch·搜索引擎
野犬寒鸦1 天前
Java8 ConcurrentHashMap 深度解析(底层数据结构详解及方法执行流程)
java·开发语言·数据库·后端·学习·算法·哈希算法
百锦再1 天前
Java IO详解:File、FileInputStream与FileOutputStream
java·开发语言·jvm·spring boot·spring cloud·kafka·maven