定义
Ribbon 做为负载均衡器首先会从注册中心获取可用的服务实例,然后会通过负载均衡机制为服务消费者选择调用哪一个服务实例,从而达到缓解网络压力和扩容的目的。同时也具备容灾的作用,不会应为莫一台实例故障而导致系统不可用。负载均衡策略常见的有轮询负载,权重负载,按流量负载,同时Ribbon也支持自定义负载策略。
负载策略
️RandomRule:随机策略会通过一个随机数从可用服务实例中选择一个实例。实现是用一个while循环,如果实例为空则执行随机选择,直到获取到。该策略有不严谨的地方,如果一直获取不到,很可能出现死循环的情况。
️RoundRobinRule:按照线性轮训的方式选择可用的实例。该策略定义了一个计数器的变量,每次循环后计数器累加 ,如果10次选择不到服务实例,则提示无可用服务。
️RetryRule:该策略增加了重试的机制,默认使用RoundRobinRule策略,如果超过时间阙值则返回null。
️WeightedResponseTimeRule:是在RoundRobinRule的基础上增加权重的策略,会根据实例的响应以及运行情况分配负载的权重,以便更好的利用资源,达到最优化。
️BestAvailableRule:遍历所有可用实例,过滤到故障实例,选择出请求并发数最小的一个。也就是说会优先选择空闲实例。
例子
例子源码请参见 https://github.com/githubweili/springcloud/tree/master/spring-cloud-learn/cloud-consumer
pom文件增加依赖 spring-cloud-starter-netflix-ribbon,配置文件 application.yml 不需要修改。
java 代码 HelloService 声明 RestTemplate,RestTemplate是 spring提供的用于访问Rest服务的客户端。可通过 ClientHttpRequestFactory 指定不同的 Http 请求实现。SimpleClientHttpRequestFactory 使用 J2SE提供的方式,HttpComponentsClientHttpRequestFactory 使用的是 HttpClient 实现。
启动两个 cloud-service实例,注意要设置不同的端口 8085和8086,在启动服务消费者 cloud-consumer,这时候可以在注册中心清晰的看到有两个服务提供者,一个服务消费者。这时候访问消费者的接口 localhost:8083/hello?name=test 不断刷新就会出现负载均衡的效果,页面返回 hello test i am from port 8085,hello test i am from port 8086,默认是轮询负载策略。
作者:把代码写成诗
版权所有,转载请注明出处
欢迎关注,沟通交流 https://github.com/githubweili
网友评论