SpringCloud学习 系列九、Ribbon

系列导航

SpringCloud学习 系列一、 前言-为什么要学习微服务

SpringCloud学习 系列二、 简介

SpringCloud学习 系列三、 创建一个没有使用springCloud的服务提供者和消费者

SpringCloud学习 系列四、微服务中心 Eureka介绍及创建一个Eureka中心服务

SpringCloud学习 系列五、创建生产者和消费者验证微服务中心 Eureka的作用

SpringCloud学习 系列六、服务平滑离线

SpringCloud学习 系列七、EurekaServer集群创建

SpringCloud学习 系列八、OpenFeign

SpringCloud学习 系列九、Ribbon

SpringCloud学习 系列十、服务熔断与降级(1-简介)

SpringCloud学习 系列十、服务熔断与降级(2-方法级别服务降级)

SpringCloud学习 系列十、服务熔断与降级(3-类级别的服务降级)

SpringCloud学习 系列十、服务熔断与降级(4-Dashboard监控仪表盘)

未完待续

1、Ribbon简介

Ribbon 是 Netflix 公司的一个开源的负载均衡项目,是一个客户端负载均衡器,运行在消费者端。OpenFeign 也是运行在消费者端的,使用 Ribbon 进行负载均衡,所以 OpenFeign 直接内置了 Ribbon。即在导入 OpenFeign 依赖后,无需再专门导入 Ribbon 依赖了。

2、Ribbon负载均衡示意图

 

说明:Ribbon实质就是实现了负载均衡,当有多个provider时,consumer会根据Ribbon的策略去访问provider请求服务。

3、Ribbon的负载环境搭建

(1)创建提供者 04-provider-8082

1、复制03-provider-8081重命名为04-provider-8082

2、修改配置文件

 

 

 

后面创建的集群工程微服务名称不变,只修改端口

3、修改启动类

 

4、修改控制器

输出加上端口号,这样可以知道调用的是哪一个provider的服务

 

 

 

(2)创建提供者 04-provider-8083

复制04-provider-8082重命名为04-provider-8083

其他步骤参考上面的步骤

(3)创建提供者 04-provider-8084

复制04-provider-8082重命名为04-provider-8084

其他步骤参考上面的步骤

(4)创建消费者 04-consumer-feign-8080

1、复制03-consumer-feign-8080重命名为04-consumer-feign-8080

2、修改启动类

 

3、修改配置文件

 

4、修改服务类

 

5、注释掉延时代码

 

(5)验证provider集群和Ribbon的负载功能

1、启动工程04-provider-8082、04-provider-8083、04-provider-8084、04-consumer-feign-8080、00-eurekaserver-8000

 

 

 

2、/consumer/block/get/1 测试负载

 

 

发现三个provider交替的被访问,负载是有效的。

4、Ribbon的负载策略

  上一个小节实验说明Ribbon的负载是有效的,负载的策略默认是轮询,这个经过实验验证了,实际上除了轮询还有其他的负载策略,我们本章讲解还有哪些负载。

内置负载均衡策略有如下几种

(1) RoundRobinRule

轮询策略。Ribbon 默认采用的策略。若经过一轮轮询没有找到可用的 provider,最多轮询 10 轮。若最终还没有找到,则返回 null。

(2) RandomRule

随机策略,从所有可用的 provider 中随机选择一个。

(3) RetryRule

重试策略。先按照 RoundRobinRule 策略获取 provider,若获取失败,则在指定的时限内重试。默认的时限为 500 毫秒。

(4) BestAvailableRule

最可用策略。选择并发量最小的 provider,即连接的消费者数量最少的 provider。

(5) AvailabilityFilteringRule

可用过滤算法。该算法规则是:过滤掉处于熔断状态的 provider 与已经超过连接极限的provider,对剩余 provider 采用轮询策略。

(6) ZoneAvoidanceRule

zone 回避策略。根据 provider 所在 zone 及 provider 的可用性,对 provider 进行选择。

(7) WeightedResponseTimeRule

“权重响应时间”策略。根据每个 provider 的平均响应时间计算其权重,响应时间越快权重越大,被选中的机率就越高。在刚启动时采用轮询策略。后面就会根据权重进行选择了。

5、修改Ribbon的负载策略

Ribbon 默认采用的是 RoundRobinRule,即轮询策略。但通过修改消费者工程的配置文件,或修改消费者的启动类或 JavaConfig 类可以实现更换负载均衡策略的目的。

(1)复制04-consumer-feign-8080重命名为04-consumer-feign-loadbalancer-8080

(2)修改启动类

 

(3)配置文件增加如下内容

 

(4)验证负载策略

1、启动工程04-provider-8082、04-provider-8083、04-provider-8084、04-consumer-feign-loadbalancer-8080、00-eurekaserver-8000

2、/consumer/block/get/1 测试负载

 

 

 

 

说明:上面四次查询的结果从轮询变成随机了,说明负载的策略修改成功。
posted @ 2022-12-15 16:22  万笑佛  阅读(117)  评论(0编辑  收藏  举报