Ribbon-负载均衡

目录

一、负载均衡的作用位置

二、Ribbon负载均衡的工作流程

三、IRule接口

负载均衡的策略:

修改负载均衡策略(即修改使用的IRule接口的实现类):

四、饥饿加载

五、总结


前置知识:Eureka注册中心

不熟悉Eureka的可以先看一下前一个文章(上面链接)。

一、负载均衡的作用位置

我们最开始学习的时候,用浏览器来访问的时候都是直接输入ip地址+端口号,而在上面这次请求中,我们只是用了服务的名称就能找到相应的服务,那是因为我们配置了Eureka,帮我们进行了转换,如果我们未配置Eureka,直接用之前那种localhost:userservice/test当然是不能直接成功的。

Ribbon的作用就是当我们得到一个服务列表,有多个匹配的服务时,ribbon就是做这种选择的,帮助我们选择其中的一个服务执行。当然Ribbon也是有不同的策略来选择服务的。

二、Ribbon负载均衡的工作流程

当我们发起一个请求,如http://userservice/user/1这个请求,他会被RibbonLoadBanlancerClient拦截,并且会获取到主机名:userservice然后再将该值传给DynamicSercerListLoadBalancer,然后通过这个类来向Eureka服务中心通过userservice拉取服务列表,如localhost:8081,localhost:8082等传回DynamicSercerListLoadBalancer的实例对象,再通过Rule对象,其实现IRule的接口,来完成服务负载均衡选择出一个服务,最终返回RibbonLoadBanlancerClient的对象,再修改原先的URL,重新发出请求,请求到真正的URL。

三、IRule接口

Ribbon的负载均衡规则是一个叫做IRule的接口来定义的,每一个子接口都是一种规则:

负载均衡的策略:

修改负载均衡策略(即修改使用的IRule接口的实现类):

通过定义IRule实现可以修改负载均衡规则,有两种方式:

1.代码方式:再配置类中定义一个新的IRule(全局配置,调用的所有服务都采用这种方式):

java 复制代码
@Bean
public IRule randomRule(){
    return new RandomRule();
}

2.配置文件方式:在配置文件中添加新的配置也可以修改规则,只能针对某个微服务而言(userservice):

java 复制代码
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.netfix.loadbalancer.RandomRule #负载均衡规则

四、饥饿加载

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

五、总结

1.Ribbon负载均衡规则

规则接口是IRule

默认实现是ZoneAvoidanceRule,根据zone选择服务列表,然后轮询

2.负载均衡自定义方式

代码方式:配置灵活,但修改时需要重新打包发布

配置方式:直观,方便,无需重新打包发布但是无法做全局配置

3.饥饿加载

开启饥饿加载

指定饥饿加载的微服务名称

相关推荐
张忠琳5 小时前
【client-go v0.36.1】(store Part 3)Store 超深度分析 — 集成模式、完整数据流、不变量、与 DeltaFIFO 协作
云原生·kubernetes·informer·store·client-go
赵渝强老师8 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes
鹤落晴春8 小时前
【K8s】配置存储卷
云原生·容器·kubernetes
张忠琳9 小时前
【client-go v0.36.1】(DeltaFIFO Part 1)DeltaFIFO 超深度分析 — 模块定位、类结构、接口层次、构造与初始化
云原生·kubernetes·deltafifo·informer·client-go
阿里云云原生11 小时前
实战揭秘:如何通过 AI Agent Skill 让 K8s 应用自动接入云监控?
云原生
张忠琳13 小时前
【client-go v0.36.1】tools/cache 深度分析(下篇)— RealFIFO 深度、集成架构、生命周期、设计模式总结
云原生·kubernetes·cache·informer·client-go
张忠琳13 小时前
【client-go v0.36.1】(store Part 2)Store 超深度分析 — threadSafeMap 核心、索引体系、RV追踪、事务机制
云原生·kubernetes·informer·store·client-go
sbjdhjd14 小时前
04(上)| k8s中的微服务
微服务·云原生·kubernetes·开源·云计算·excel·kubelet
小小放舟、16 小时前
@JsonCreator 注解详解——从枚举反序列化说起
spring boot·spring·spring cloud·java-ee·maven·intellij-idea·状态模式
这个DBA有点耶16 小时前
时序数据库深度对比:2026 年主流 TSDB 架构演进与选型指南
数据库·sql·云原生·架构·运维开发·时序数据库