SpringCloud(三)学习笔记之Ribbon
spring Cloud Ribbon 是一个客户端的负载均衡器,它提供对大量的HTTP和TCP客户端的访问控制。
客户端负载均衡即是当浏览器向后台发出请求的时候,客户端会向 Eureka Server 读取注册到服务器的可用服务信息列表,然后根据设定的负载均衡策略(没有设置即用默认的),抉择出向哪台服务器发送请求
Eureka默认支持Ribbon 则不需要引入Ribbon 的依赖,后面会介绍单独使用ribbon的案例
一、构建Eureka Server
【基于第二章节创建的Eureka Server】
二、构建Eureka Client提供者集群项目
mhb-cloud-producer 【服务提供者1】
mhb-cloud-producer-extend【服务提供者2】
当两个项目的spring.application.name和eureka.instance.appname相同时,组成一个微服务集群
1:pom文件
加入Eureka Client依赖
mhb-cloud-producer、mhb-cloud-producer-extend
<!--eureka客户端环境支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2:application.yml文件
mhb-cloud-producer 和 mhb-cloud-producer-extend 只有端口不同,其他一致
mhb-cloud-producer:端口 9904
mhb-cloud-producer-extend:端口9905
debug: false #关闭debug模式
spring:
application:
name: mhb-cloud-producer #应用的名称
server:
port: 9904 #应用的端口号
eureka:
instance:
appname: producer #eureka application的名称
prefer-ip-address: true #开启ip显示eureka的主机服务
#eureka仪表盘的Instances格式
instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${server.port}
client:
service-url:
#eureka服务开启了认证,要加上用户名和密码
defaultZone: http://admin:123456@localhost:8761/eureka/
#从eureka服务器注册表中获取注册表信息的时间间隔,默认30s
registry-fetch-interval-seconds: 30
#客户端发送变化同步到eureka服务器的时间间隔 默认30s
instance-info-replication-interval-seconds: 30
#询问eureka服务url信息的变化的间隔时间 默认300s
eureka-service-url-poll-interval-seconds: 300
#最初同步到eureka服务器的时间 默认40s
initial-instance-info-replication-interval-seconds: 40
#注册表是否压缩
g-zip-content: true
#eureka等待超时时间 默认是5s
eureka-server-connect-timeout-seconds: 5
#eureka等待读取时间 默认是8s
eureka-server-read-timeout-seconds: 8
#eureka客户端允许的所有eureka服务器连接的总数 默认200
eureka-server-total-connections: 200
#eureka客户端允许的所有eureka服务器主机连接的总数 默认50
eureka-server-total-connections-per-host: 50
#心跳执行程序线程池的大小 默认是5
heartbeat-executor-thread-pool-size: 5
#心跳重试延迟的最大倍数值 默认是10
heartbeat-executor-exponential-back-off-bound: 10
#执行程序缓存刷新线程池的大小 默认是5
cache-refresh-executor-thread-pool-size: 5
#执行程序缓存刷新重试延迟的最大倍数值 默认是10
cache-refresh-executor-exponential-back-off-bound: 10
3:启动类注解
mhb-cloud-producer、mhb-cloud-producer-extend
EnableEurekaClient/*eureka客户端注解*/
4:构建测试controller
mhb-cloud-producer、mhb-cloud-producer-extend
com\applesnt\controller\ProducerController.java
访问路径:http://localhost:端口/producer/get/123
/*类访问路径*/
@RequestMapping("/producer")
/*返回传递过来的id
* 请求路径:http://localhost:端口/producer/get/123
* */
@GetMapping("/get/{id}")
public String getId(@PathVariable("id") String id){
System.out.println("-----"+id);
return "我是提供者 端口是9904 传递的参数= "+id;
}
三、构建Eureka Client消费者项目
mhb-cloud-consumer :端口 8802
1:pom文件
Eureka 中已经自带Ribbon支持,所以不用单独引入Ribbon依赖
<!--eureka客户端环境支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2:application.yml文件
包含Ribbon的属性配置
debug: false
spring:
application:
name: mhb-cloud-consumer #每一个微服务必须有这个应用名称
server:
port: 8802 #端口
eureka:
instance:
appname: consumer #eureka application的名称
prefer-ip-address: true #开启ip显示eureka的主机服务
#eureka仪表盘的Instances格式
instance-id: ${spring.application.name}:${spring.cloud.client.ip-address}:${server.port}
client:
service-url:
defaultZone: http://admin:123456@eureka1.com:8762/eureka/,http://admin:123456@eureka2.com:8762/eureka/,http://admin:123456@eureka3.com:8763/eureka/
#从eureka服务器注册表中获取注册表信息的时间间隔,默认30s
registry-fetch-interval-seconds: 30
#客户端发送变化同步到eureka服务器的时间间隔 默认30s
instance-info-replication-interval-seconds: 30
#询问eureka服务url信息的变化的间隔时间 默认300s
eureka-service-url-poll-interval-seconds: 300
#最初同步到eureka服务器的时间 默认40s
initial-instance-info-replication-interval-seconds: 40
#注册表是否压缩
g-zip-content: true
#eureka等待超时时间 默认是5s
eureka-server-connect-timeout-seconds: 5
#eureka等待读取时间 默认是8s
eureka-server-read-timeout-seconds: 8
#eureka客户端允许的所有eureka服务器连接的总数 默认200
eureka-server-total-connections: 200
#ribbon预加载
ribbon:
eager-load:
enabled: true #预加载 服务器启动的时候就加载服务列表 建议开启
clients: mhb-cloud-producer #预加载哪个微服务 多个话用逗号隔开
#ribbon需要负载均衡的服务属性配置
mhb-cloud-producer: #配置的哪个实例
ribbon:
# 代表Ribbon使用的负载均衡策略(轮询)
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule
# 每台服务器最多重试次数,但是首次调用不包括在内
MaxAutoRetries: 1
# 最多重试多少台服务器
MaxAutoRetriesNextServer: 1
# 无论是请求超时或者socket read timeout都进行重试
OkToRetryOnAllOperations: true
# 服务列表的更新频率 毫秒
ServerListRefreshInterval: 2000
# 连接超时时间
ConnectTimeout: 3000
# 读取超时时间
ReadTimeout: 3000
Ribbon负载均衡策略包括:
[1]BestAvailableRule:选择一个最小的并发请求的server:
[2]AvailabilityFilteringRule:过滤掉那些因为一直连接失败的被标记为circuittripped的后端server,并过滤掉那些高并发的的后端server
[3]WeightedResponseTimeRule:根据响应时间分配一个weight,响应时间越长,weight越小,被选中的可能性越低。
[4]RetryRule:对选定的负载均衡策略机上重试机制
[5]RoundRobinRule:roundRobin方式轮询选择server
[6]RandomRule:随机选择一个server
[7]ZoneAvoidanceRule:复合判断server所在区域的性能和server的可用性选择server
3:启动类配置RestTemplate
@@EnableEurekaClient
balanceRestTemplate:是带负载均衡的RestTemplate
noBalanceRestTemplate:是不带负载均衡的RestTemplate
package com.applesnt;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.ribbon.RibbonClientConfiguration;
import org.springframework.cloud.netflix.ribbon.RibbonClients;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Primary;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
@EnableEurekaClient
public class MhbCloudConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(MhbCloudConsumerApplication.class, args);
}
@Bean
@LoadBalanced/*微服务通讯时需要负载均衡 相同的spring.applincatin.name*/
public RestTemplate balanceRestTemplate(){
return new RestTemplate();
}
@Primary
@Bean/*微服务通讯时不需要负载均衡*/
public RestTemplate noBalanceRestTemplate(){
return new RestTemplate();
}
}
4:编写消费者远程调用controller
com\applesnt\controller\RibbonConsumerController.java
注入使用负载均衡和不使用负载均衡的RestTemplate,用@Qualifier来加以区分引入的对象
如果不使用负载均衡的RestTemplate,支持http://localhost:9904这种请求格式,不支持http://mhb-cloud-producer这种请求格式
如果使用负载均衡的RestTemplate, 支持http://mhb-cloud-producer这种请求格式,不支持http://localhost:9904这种请求格式
访问路径:http://localhost:8802/ribbon/get/123
package com.applesnt.controller;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
@RequestMapping("/ribbon")
@Slf4j
public class RibbonConsumerController {
/*注入 RestTemplate 在启动类中已初始化 不使用负载均衡*/
@Autowired
@Qualifier("noBalanceRestTemplate")
private RestTemplate noBalanceRestTemplate;
/*注入 RestTemplate 在启动类中已初始化 使用负载均衡*/
@Autowired
@Qualifier("balanceRestTemplate")
private RestTemplate balanceRestTemplate;
@GetMapping("/get/{id}")
public String old(@PathVariable("id") String id){
/*
* 如果不使用负载均衡的RestTemplate,支持http://localhost:9904这种请求格式
* 如果使用负载均衡的RestTemplate 则不支持http://localhost:9904这种请求格式
* */
String result="";
/*正确输出*/
result = noBalanceRestTemplate.getForObject("http://localhost:9904/producer/get/"+id,String.class);
log.info("不使用负载均衡noBalanceRestTemplate==result:"+result);
result = balanceRestTemplate.getForObject("http://mhb-cloud-producer/producer/get/"+id,String.class);
log.info("使用负载均衡-url为微服务的balanceRestTemplate==result:"+result);
return result;
}
}
5:服务启动
分别启动eureka服务集群、mhb-cloud-producer、mhb-cloud-producer-extend、mhb-cloud-consumer六个服务
http://eureka1.com:8761/
6:Ribbon负载测试
Ribbon使用的是轮询方式
访问路径:http://localhost:8802/ribbon/get/123
第一次访问结果:
第二次访问结果:
四、LoadBalancerClient对象
/*ribbon 注入操作对象*/
@Autowired
private LoadBalancerClient loadBalancerClient;
@GetMapping("/get/lbc/{id}")
public void ribbon(@PathVariable("id") String id){
/*负载均衡得到当前连接的是集群中的哪一个微服务*/
ServiceInstance instance = loadBalancerClient.choose("mhb-cloud-producer");
log.info("ServiceId="+instance.getServiceId()+" url="+instance.getUri()+" 端口="+instance.getPort());
try {
/*根据负载均衡后的服务构建url路径*/
URI uri1 = loadBalancerClient.reconstructURI(instance,new URI(""));
log.info("uri1="+uri1);
/*构建url路径 默认是http*/
URI uri2 = loadBalancerClient.reconstructURI(instance,new URI("/producer/get/"+id));
log.info("uri2="+uri2);
/*构建https url路径*/
URI uri3 = loadBalancerClient.reconstructURI(instance,new URI("https:/producer/get/"+id));
log.info("uri3="+uri3);
}catch (Exception e){
}
}
五:Ribbon脱离Eureka的使用
Eureka之外的服务调用 比如第三方
mhb-cloud-consumer-ribbon【端口:8803】
1:pom文件【不在引入eureka的依赖】
<!--引入ribbon的依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
2:application.yml文件
debug: false
spring:
application:
name: mhb-cloud-consumer-ribbon #每一个微服务必须有这个应用名称
server:
port: 8803 #端口
mhb-cloud-producer: #配置的哪个实例
ribbon:
listOfServers: 127.0.0.1:9904,127.0.0.1:9905
# 代表Ribbon使用的负载均衡策略
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule
3:启动类:【不在使用@EnableEurekaClient注解】
package com.applesnt;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
public class MhbCloudConsumerRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(MhbCloudConsumerRibbonApplication.class, args);
}
@Bean
@LoadBalanced/*微服务通讯时需要负载均衡 相同的spring.applincatin.name*/
public RestTemplate balanceRestTemplate(){
return new RestTemplate();
}
}
4:业务测试类:
com\applesnt\controller\RibbonConsumerController.java
package com.applesnt.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
/**
* @author: menghaibin
* @create: 2020-03-08 20:15
* @description: Ribbon消费者控制层
**/
@RestController
@RequestMapping("/ribbon")
public class RibbonConsumerController {
/*注入 RestTemplate 在启动类中已初始化 使用负载均衡*/
@Autowired
private RestTemplate balanceRestTemplate;
@GetMapping("/get/{id}")
public String old(@PathVariable("id") String id){
String result = null;
/*获取配置文件中mhb-cloud-producer的服务列表*/
result = balanceRestTemplate.getForObject("http://mhb-cloud-producer/producer/get/"+id,String.class);
return result;
}
}
测试:
http://127.0.0.1:8803/ribbon/get/123
第一次访问:
第二次访问:
SpringCloud(三)学习笔记之Ribbon的更多相关文章
- springcloud Eureka学习笔记
最近在学习springcloud,抽空记录下学习笔记;主要记录Eureka的实现过程和高可用性的实现 Eureka是一个服务治理框架,它提供了Eureka Server和Eureka Client两个 ...
- SpringCloud学习笔记(2)——Ribbon
参考SpringCloud官网第16.17章 16. Client Side Load Balancer: Ribbon Ribbon是一个客户端的负载均衡器,它提供对大量的HTTP和TCP客户端的访 ...
- SpringCloud Alibaba学习笔记
目录 目录 目录 导学 为什么学 学习目标 进阶目标 思路 Spring Cloud Alibaba的重要组件 环境搭建 Spring Boot必知必会 Spring Boot特性 编写第一个Spri ...
- spring cloud学习笔记二 ribbon负载均衡
Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为.为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求.Ribb ...
- SpringCloud(六)学习笔记之Zuul
Zuul 在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架.Zuul 相当于是设备和 Netflix 流应用的 Web 网站后端所有请求的前门 Hystrix+Ribbon(不使用Feign) ...
- SpringCloud(五)学习笔记之Hystrix
在微服务架构中多层服务之间会相互调用,如果其中有一层服务故障了,可能会导致一层服务或者多层服务故障,从而导致整个系统故障.这种现象被称为服务雪崩效应. Hystrix组件就可以解决此类问题,Hystr ...
- SpringCloud(四)学习笔记之Feign
Feign是一个声明式的Web服务客户端,可帮助我们更加便捷.优雅地调用HTTP API Feign可以与Eureka和Ribbon组合使用以支持负载均衡 一.构建Eureka Server [基于第 ...
- springcloud Zuul学习笔记
SpringCloud Zull是一个基于NetflixZuul实现的API网关组件,它实现了请求路由,负载均衡,校验过滤等功能;本文主要记录springcloud zuul的入门级demo开发过程; ...
- SpringCloud(一)学习笔记之项目搭建
[springcloud项目名称不支持下划线] 一.创建父项目 File---new---project: 填写项目信息: 默认即可,点击finish创建完成: 由于父项目只用到pom文件 所以把sr ...
随机推荐
- nim博弈 LightOJ - 1253
主要是写一下nim博弈的理解,这个题有点奇怪,不知道为什么判断奇偶性,如果有大佬知道还请讲解一下. //nim博弈 //a[0]~a[i] 异或结果为k 若k=0 则为平衡态 否则为非平衡态 //平衡 ...
- 吴恩达DeepLearning.ai的Sequence model作业Dinosaurus Island
目录 1 问题设置 1.1 数据集和预处理 1.2 概览整个模型 2. 创建模型模块 2.1 在优化循环中梯度裁剪 2.2 采样 3. 构建语言模型 3.1 梯度下降 3.2 训练模型 4. 结论 ...
- PHP序列化及反序列化分析学习小结
PHP反序列化 最近又遇到php反序列化,就顺便来做个总结. 0x01 PHP序列化和反序列化 php序列化:php对象 序列化的最主要的用处就是在传递和保存对象的时候,保证对象的完整性和可传递性.序 ...
- B - Bound Found POJ - 2566(尺取 + 对区间和的绝对值
B - Bound Found POJ - 2566 Signals of most probably extra-terrestrial origin have been received and ...
- Pytest系列(8) - 使用自定义标记mark
如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 pytest 可以支持自定义 ...
- Java的多线程1:线程的使用
概述 进程是线程的容器,线程共享进程的内存空间,所以线程之间彼此通信是比较容易的,而线程又有自己私有的内存地址,其他线程无法访问.了解进程和线程关系,可以看我另一篇博客<进程与线程> Ja ...
- php连接数据库,php连接mysql并查询的几种方式,PHP PDO连接以及预处理
PHP连接数据库 面向过程 $config = [ 'host'=>'127.0.0.1', //数据库地址 'name'=>'test', //库名 'user'=>'root', ...
- 【Linux】系统管理
软件包管理 一 软件包分类 源码包: .tar.gz .tar.bz2 二进制包: .rpm 二 二进制包安装 (一) rpm命令手动管理二进制包 (挂载光盘) 1 包名-版本号-发布次数-适合lin ...
- C#多线程系列(1):Thread
目录 1,获取当前线程信息 2,管理线程状态 2.1 启动与参数传递 2.1.1 ParameterizedThreadStart 2.1.2 使用静态变量或类成员变量 2.1.3 委托与Lambda ...
- JS 浏览器BOM-->open() 方法
1.定义和用法 open() 方法用于打开一个新的浏览器窗口或查找一个已命名的窗口. 语法: window.open(URL,name,specs,replace) 参数: URL:打开指定的页面的U ...