1.提出问题

1.如何从多个服务集群中选择具体的服务?
从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址

2.Ribbon组件

2.1.Ribbon组件的作用

:::info 作用:实现负载均衡功能
从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址
:::

2.2.负载均衡原理

1.总结图

:::info SpringCloudRibbon的底层采用了一个拦截器,拦截了RestTemplate发出的请求
::: image.png

2.基本流程如下

:::info

  • 拦截我们的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组件的使用步骤

:::info 1.SpringCloud底层已经封装了Ribbon的组件,所以使用Ribbon组件只需要在RestTemplate这个Bean添加一个@LoadBalanced注解
2.@LoadBalanced注解:RestTemplate在远程访问时,自动从Eureka服务器中获取远程访问服务地址,如果远程服务器有多个地址,则自动负载均衡 ::: image.png

4.负载均衡策略

1.内置均衡策略

image.png

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

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

  1. @Bean
  2. public IRule randomRule(){
  3. return new RandomRule();
  4. }

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

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

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

5.负载均衡加载方式

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

ribbon:
  eager-load:
    enabled: true 
    clients: userservice    #开启饥饿加载的服务