Ribbon-负载均衡原理解析(案例)

简介:负载均衡,英文名称为Load Balance,其含义就是指将负载(工作任务)进行平衡、分摊到多个操作单元上进行运行,例如FTP服务器、Web服务器、企业核心应用服务器和其它主要任务服务器等,从而协同完成工作任务。

负载均衡主要分为软件负载和硬件负载,在微服务盛行的现在,软件负载在微服务里成为主流,netflix的ribbon就是其中之一。

目录

1、负载均衡原理

[1.1 负载均衡流程](#1.1 负载均衡流程)

[1.2 负载均衡原理](#1.2 负载均衡原理)

2、负载均衡策略

[2.1 负责均衡规则](#2.1 负责均衡规则)

[2.2 负责均衡策略](#2.2 负责均衡策略)

3、饥饿加载


1、负载均衡原理

1.1 负载均衡流程

图 1.1-1 负载均衡流程
上图中展示的是负载均衡流程:首先是服务(order-service)发起请求,请求被Ribbon(负载均衡)接收并且去拉取eureka-server的注册信息,让其返回服务列表,在服务列表中选择合适的服务。

1.2 负载均衡原理

图 1.2-1 负载均衡原理
上图中展示的是负载均衡原理,图中介绍比较详细,这里就不做过多说明了。 其中比较重要的是选择服务列表中的服务对象方法有两个,定义在IRule接口里面:一是轮询调度,而是随机数。

2、负载均衡策略

2.1 负责均衡规则

图 2.1-1 负责均衡规则
从图中我们可以看到,日常使用的调度规则 "ZoneAvoidanceRule" 集成自轮询调度

2.2 负责均衡策略

图 2.2 负责均衡策略
上图中展示的是负责均衡策略,有两种方式:一种是在启动类中创建一个 返回IRule的对象,作用域是针对所有的微服务,另一种是修改配置文件。

3、饥饿加载

图 3-1 饥饿加载
上图中展示的是饥饿加载。

4、总结

相关推荐
库里不会投三分6 小时前
谢飞机面试记:从JVM到Spring AI的3轮灵魂拷问(音视频+AI招聘双场景)
spring cloud·java面试·rag·spring ai·ai招聘·音视频架构
运维行者_6 小时前
用Applications Manager监控HAProxy:保障负载均衡高效稳定
运维·开发语言·前端·数据库·tcp/ip·负载均衡·服务器监控
岁岁种桃花儿10 小时前
SpringCloud从入门到上天:分布式和微服务基础
分布式·spring cloud·微服务
爱吃山竹的大肚肚1 天前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
k_cik_ci1 天前
什么是负载均衡?
服务器·网络·负载均衡
hwj运维之路1 天前
超详细ubuntu22.04部署k8s1.28高可用(一)【多master+keepalived+nginx实现负载均衡】
运维·云原生·kubernetes·负载均衡
鸽鸽程序猿1 天前
【JavaEE】【SpringCloud】分布式事务 Alibaba Seata
分布式·spring cloud·java-ee
没有bug.的程序员1 天前
Spring Cloud Sentinel:熔断降级规则配置与分布式流量防线实战终极指南
java·分布式·后端·spring cloud·sentinel·熔断规则·分布式流量防线
梵得儿SHI1 天前
实战项目落地:微服务拆分原则(DDD 思想落地,用户 / 订单 / 商品 / 支付服务拆分实战)
spring cloud·微服务·云原生·架构·微服务拆分·ddd方法论·分布式数据一致性
努力也学不会java1 天前
【Spring Cloud】优雅实现远程调用-OpenFeign
java·人工智能·后端·spring·spring cloud