Ribbon跟Nginx实现负载均衡的区别!

一,

Ribbon是在客户端去进行请求的分发,而Nginx则是服务器端的

下面是Ribbon的源码

public Server choose(ILoadBalancer lb, Object key) {

if (lb == null) {

log.warn("no load balancer");

return null;

} else {

Server server = null;

int count = 0;

while(true) {

if (server == null && count++ < 10) {

List<Server> reachableServers = lb.getReachableServers();

List<Server> allServers = lb.getAllServers();

int upCount = reachableServers.size();

int serverCount = allServers.size();

if (upCount != 0 && serverCount != 0) {

int nextServerIndex = this.incrementAndGetModulo(serverCount);

server = (Server)allServers.get(nextServerIndex);

if (server == null) {

Thread.yield();

} else {

if (server.isAlive() && server.isReadyToServe()) {

return server;

}

server = null;

}

continue;

}

log.warn("No up servers available from load balancer: " + lb);

return null;

}

if (count >= 10) {

log.warn("No available alive servers after 10 tries from load balancer: " + lb);

}

return server;

}

}

}

private int incrementAndGetModulo(int modulo) {

int current;

int next;

do {

current = this.nextServerCyclicCounter.get();

next = (current + 1) % modulo;

//while 自旋操作

} while(!this.nextServerCyclicCounter.compareAndSet(current, next));

return next;

}

二,工作原理

  • Ribbon:Ribbon 通过在客户端维护服务实例列表和选择算法来实现负载均衡。客户端应用程序通过 Ribbon 客户端负载均衡器来选择要发送请求的服务实例。
  • Nginx:Nginx 在服务器端实现负载均衡,它接收来自客户端的请求,并根据预先配置的负载均衡策略将请求分发给多个后端服务器。Nginx 可以根据请求的不同特征,如 IP 地址、HTTP 头部等,使用不同的负载均衡算法。

三,性能跟灵活性

  • Ribbon:Ribbon 作为客户端库集成到应用程序中,对于每个请求都需要在客户端进行负载均衡选择,可能会增加客户端的负载和延迟。
  • Nginx:Nginx 是一个高性能的反向代理服务器,通过在服务器端实现负载均衡,可以有效地减轻客户端的负载,并提供更好的性能和灵活性。

总结

总的来说,Ribbon 适用于微服务架构中服务消费方的负载均衡,而 Nginx 则适用于各种类型的应用程序和服务,提供了更灵活、高性能的负载均衡解决方案。

相关推荐
农村小镇哥9 小时前
nginx服务器的介绍
运维·服务器·nginx
llm大模型算法工程师weng17 小时前
负载均衡做什么?nginx是什么
运维·开发语言·nginx·负载均衡
fTiN CAPA18 小时前
服务器无故nginx异常关闭之kauditd0 kswapd0挖矿病毒 CPU占用200% 内存耗尽
运维·服务器·nginx
lKWO OMET20 小时前
查看 nginx 是否已经启动
运维·数据库·nginx
ywlovecjy1 天前
【Nginx 】Nginx 部署前端 vue 项目
前端·vue.js·nginx
hutengyi1 天前
四、nginx的优化和location匹配规则
运维·nginx
eEKI DAND1 天前
一个比 Nginx 还简单的 Web 服务器
服务器·前端·nginx
Watermelo6172 天前
理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事
前端·javascript·vue.js·chrome·nginx·正则表达式·seo
Cyber4K2 天前
【Nginx专项】高级进阶架构篇-Location、Rewrite及HTTPS
服务器·nginx·架构·https
博风2 天前
nginx:前后端分离常用配置
nginx