1.提出问题
1.如何从多个服务集群中选择具体的服务?
从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址
2.Ribbon组件
2.1.Ribbon组件的作用
:::info
作用:实现负载均衡功能
从服务列表中利用Ribbon负载均衡按照其中的负载均衡策略选择一个服务的地址
:::
2.2.负载均衡原理
1.总结图
:::info
SpringCloudRibbon的底层采用了一个拦截器,拦截了RestTemplate发出的请求
:::
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服务器中获取远程访问服务地址,如果远程服务器有多个地址,则自动负载均衡
:::
4.负载均衡策略
1.内置均衡策略
2.自定义设置负载均衡策略
1.方式一:代码方式:定义一个新的IRule的bean对象
@Beanpublic 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.负载均衡加载方式
:::info Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。通过配置文件修改加载方式: :::
ribbon:
eager-load:
enabled: true
clients: userservice #开启饥饿加载的服务
