消费者使用服务名访问时,并不是一个真实可用的地址
因此。消费者通过服务名请求时会被ribbon拦截,ribbon在向注册中心拉起提供者信息(地址,端口),在将拉取到的信息通过负载均衡规则请求到提供者
负载均衡流程图:
Ribbon的负载均衡规则是一个叫做IRule的接口来定义的,每一个子接口都是一种规则
部分规则介绍:
自定义负载均衡策略
代码方式
/**
* 设置为负载均衡为随机策略
*/
@Bean
public IRule randomRule() {
return new RandomRule();//返回负载均衡规则类对象
}
该方式设配置为全局有效,消费者访问任何服务皆是以此规则
配置文件方式
# 针对userservice设置负载均衡规则
userservice:
ribbon:
#负载均衡规则类的路径.名称
NFLoadBalancerRuleclassName: com.netflix.loadbalancer.RandomRule
该方式配置为局部有效,消费者访问特定的服务(userservice)时的负载均衡规则
饥饿加载:
Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:
ribbon:
eager-load:
enabled: true #开启饥饿加载
clients: #指定饥饿加载的服务名称
- USERSERVICE
- ORDERSERVICE