Ribbon-负载均衡

复制代码
负载方案:
1.在客户端和服务端中间使用独立的代理方式进行负载,Nginx
2.消费端根据自己的请求做负载均衡,Ribbon

常见算法:
	随机:通过随机选择服务进行执行
	轮询:默认实现方式,服务请求 一个接着一个 依次处理
	权重:对服务器性能的分析,给高配置,低负载的服务器分配更高的权重
    最小连接数:哪台服务器接收请求连接越少,就分给哪台

1. Ribbon常用负载均衡策略

复制代码
IRule:所有负载均衡策略的父接口,核心方法choose方法,通过服务名称选择服务实例。
AbstractLoadBalancerRule:抽象类,主要定义了一个ILoadBalancer,辅助负载均衡策略选取合适的服务端实例。
RandomRule:随机策略,每次通过底层方法生成一个不大于服务器实例总数的随机数,并将该数作为下标获取一个服务实例。
RoundRobinRule:轮询策略,开启一个计数器,在while循环中遍历服务清单,获取清单之前先通过底层方法获取一个下标,这个下标是一个不断自增长的数先+1然后和服务清单总数取模之后获取到的,再通过这个小标去服务清单中获取服务实例。
RetryRule:重试策略,在轮询的基础上进行重试,比如在轮询的过程中选择的服务实例为null或者已失效,则在请求超时时间范围内会不断的进行重试获取服务实例。
WeightedResponseTimeRule:权重策略,底层方法会根据每一个服务实例的运行情况计算出该实例的一个权重数,然后在挑选服务实例的时候则根据权重进行挑选,能够实现更优的服务实例调用。

2.修改Ribbon负载均衡策略

1.方式一:配置类
复制代码
自定义负载均衡策略配置类要放在启动类扫描包路径之外,否则自定义的配置类会被所有的服务提供方共享。
1.修改Ribbon负载均衡策略配置类
java 复制代码
@Configuration
public class RibbonRandomRuleConfig {

    @Bean
    //方法名iRule不要修改
    public IRule iRule(){
        return new RandomRule();
    }

}
2.启动类添加RibbonClients注解
复制代码
注:使用RestTemplete进行接口调用,需要添加@LoadBalanced注解
java 复制代码
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
@MapperScan({"com.daily.project.mapper"})
@EnableFeignClients
@RibbonClients(value = {
        //服务提供方,也就是当前服务需要调用的服务
        //当前服务调用daily-project-system时采用Ribbon负载均衡随机策略
        @RibbonClient(name="daily-project-system",configuration = RibbonRandomRuleConfig.class)
})
public class TrainSportApplication {
    public static void main(String[] args) {
        SpringApplication.run(TrainSportApplication.class, args);
    }
    
	@Bean
    @LoadBalanced
    public RestTemplate restTemplate(RestTemplateBuilder builder){
        RestTemplate restTemplate = builder.build();
        return restTemplate;
    }
}
2.方式二:配置文件yml
yaml 复制代码
#服务提供方
#服务提供方
daily-project-system:
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule
##第一次访问服务ribbon默认懒加载响应慢的问题
ribbon:
  eager-load:
    #开启ribbon饥饿加载(服务启动时就加载)
    enabled: true
    #多个使用,分隔
    clients: daily-project-system
相关推荐
鬼先生_sir7 小时前
SpringCloud-Sentinel(熔断降级 & 流量控制)
spring·spring cloud·sentinel
木子欢儿1 天前
Docker Hub 镜像发布指南
java·spring cloud·docker·容器·eureka
Devin~Y1 天前
高并发电商与AI智能客服场景下的Java面试实战:从Spring Boot到RAG与向量数据库落地
java·spring boot·redis·elasticsearch·spring cloud·kafka·rag
鬼先生_sir1 天前
Spring Cloud 微服务监控实战:SkyWalking + Prometheus+Grafana 全栈解决方案
运维·spring cloud·grafana·prometheus·skywalking
文慧的科技江湖1 天前
光储充协同的终极闭环:用SpringCloud微服务打造“发-储-充-用“智能能源网络 - 慧知开源充电桩管理平台
java·开发语言·spring cloud·微服务·能源·充电桩开源平台·慧知重卡开源充电桩平台
鬼先生_sir1 天前
SpringCloud-Stream + RocketMQ/Kafka
spring cloud·kafka·rocketmq·stream
小江的记录本2 天前
【JEECG Boot】 JEECG Boot——数据字典管理 系统性知识体系全解析
java·前端·spring boot·后端·spring·spring cloud·mybatis
杰克尼2 天前
springCloud(day10-面试篇)
redis·spring cloud·面试
鬼先生_sir2 天前
Spring Cloud LoadBalancer 详解:从原理到生产实战(2026最新版)
spring cloud·负载均衡·loadbalancer
QC·Rex2 天前
Spring Boot 3 微服务架构实战:从零构建企业级分布式系统
spring cloud·微服务架构·java 17·分布式系统·spring boot 3