微服务学习:Ribbon实现客户端负载均衡,将请求分发到多个服务提供者
2023-12-15 12:29:56
Ribbon是Netflix开源的一个基于HTTP和TCP客户端负载均衡器。它主要用于在微服务架构中实现客户端负载均衡,将请求分发到多个服务提供者上,从而实现高可用性和扩展性。
Ribbon的主要特点包括:
-
客户端负载均衡:Ribbon是一个客户端负载均衡器,它将负载均衡算法放到了客户端,而不是像传统的负载均衡器那样放到服务器端。这样可以更灵活地进行负载均衡,并且可以避免单点故障问题。
-
多种负载均衡算法:Ribbon支持多种负载均衡算法,如轮询、随机、加权轮询等,可以根据实际需求进行选择。
-
与Eureka集成:Ribbon可以与Eureka服务注册中心进行集成,从而自动获取可用的服务实例列表。
-
支持自定义:Ribbon提供了丰富的配置项,可以通过配置文件或编程方式来进行自定义,以满足不同的需求。
-
Spring Cloud集成:Ribbon是Spring Cloud中默认的客户端负载均衡器,可以与其他Spring Cloud组件无缝集成,比如Zuul、Feign等。
通过定义IRule实现可以修改负载均衡规则,有两种方式:
一,代码
application类中
@Bean
public IRule randomRule(){
return new RandomRule();
}
?二,配置文件
application.yml中
所调用的另一个服务的名称:
ribbon:
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.ZoneAvoidanceRule # 轮询负载均衡规则
注意:bean配置优先级高于yml配置优先级
根据集群负载均衡
所调用的另一个服务的名称:
ribbon:
NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
饥饿加载
Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。
而饥饿加载则会在项目启动时创建,降低第一次访问的耗时。
ribbon:
eager-load:
enabled: true # 开启饥饿加载
clients: userserver # 指定对userserver这个服务饥饿加载
总结:
1.Ribbon负载均衡规则:
?规则接口是IRule
?默认实现是ZoneAvoidanceRule,根据zone选择服务列表,然后轮询
2.负载均衡自定义方式
?代码方式:配置灵活,但修改时需要重新打包发布
?配置方式:直观,方便,无需重新打包发布,但是无法做全局配置
文章来源:https://blog.csdn.net/A2029292473/article/details/134881666
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!