微服务负载均衡组件Ribbon负载均衡

Ribbon是SpringCloud中的客户端负载均衡器,它与RestTemplate结合,根据负载均衡策略从服务列表中选择服务地址。负载均衡策略包括内置的随机规则等,也可以自定义通过代码或配置文件方式设定。此外,文章还介绍了如何通过配置改变Ribbon的加载方式,如启用饥饿加载。
摘要由CSDN通过智能技术生成

目录

1.提出问题

2.Ribbon组件

2.1.Ribbon组件的作用

2.2.负载均衡原理

1.总结图

2.基本流程如下

3.源码

3.Ribbon组件的使用步骤

4.负载均衡策略

1.内置均衡策略

2.自定义设置负载均衡策略

1.方式一:代码方式:定义一个新的IRule的bean对象

2.方式二:配置文件方式:在application.yml文件中,修改规则

说明:服务名称不写,就是全局生效,写服务名称,就是该服务生效

5.负载均衡加载方式


1.提出问题

1.如何从多个服务集群中选择具体的服务?

从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址

2.Ribbon组件

2.1.Ribbon组件的作用

作用:实现负载均衡功能

从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址

2.2.负载均衡原理

1.总结图

SpringCloudRibbon的底层采用了一个拦截器,拦截了RestTemplate发出的请求

2.基本流程如下

  • 拦截我们的RestTemplate请求http://userservice/user/1
  • RibbonLoadBalancerClient会从请求url中获取服务名称,也就是user-service
  • DynamicServerListLoadBalancer根据user-service到eureka拉取服务列表
  • eureka返回列表,localhost:8081、localhost:8082
  • IRule利用内置负载均衡规则,从列表中选择一个,例如localhost:8081
  • RibbonLoadBalancerClient修改请求地址,用localhost:8081替代userservice,得到http://localhost:8081/user/1,发起真实请求

3.源码

源码连接

3.Ribbon组件的使用步骤

1.SpringCloud底层已经封装了Ribbon的组件,所以使用Ribbon组件只需要在RestTemplate这个Bean添加一个@LoadBalanced注解

2.@LoadBalanced注解:RestTemplate在远程访问时,自动从Eureka服务器中获取远程访问服务地址,如果远程服务器有多个地址,则自动负载均衡

4.负载均衡策略

1.内置均衡策略

2.自定义设置负载均衡策略

1.方式一:代码方式:定义一个新的IRule的bean对象

@Bean
public IRule randomRule(){
    return new RandomRule();
}

2.方式二:配置文件方式:在application.yml文件中,修改规则

userservice: # 给某个微服务配置负载均衡规则,这里是userservice服务
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 
userservice:	# 给某个微服务配置负载均衡规则,这里是userservice服务 不写全局生效
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则 
说明:服务名称不写,就是全局生效,写服务名称,就是该服务生效

5.负载均衡加载方式

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。通过配置文件修改加载方式:

ribbon:
  eager-load:
    enabled: true 
    clients: userservice    #开启饥饿加载的服务 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值