Ribbon负载均衡(四)
一、Ribbon定义
spring cloud Ribbon是基于Netflix Ribbon实现的一套客户端,负载均衡工具
简单的说,Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法
,将Netflix的中间层服务层连接在一起.Ribbon客户端组件提供一系列完善的配置项如连接
超时,重试等.简单的说,就是在配置文件中列出Load Balancer(简称LB)后面所有的机器,
Ribbon会自动的帮助你基于某种规则(如简单轮询,随机连接等)去连接这些机器.我们很容易使用Ribbon实现自定义的负载均衡算法
ribbon原理图:
二、LB负载均衡

集中式LB
即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,比如F5,也可以是软件,如Nginx)由该设施负责把访问请求通过某一种策略转发至服务的提供者;
进程式LB
将LB逻辑集成到消费方,消费方从服务中心获取知有哪些地址可用,然后自己再从这些地址中选择出一个合适的服务器.
Ribbon就属于进程内LB,它只是一个类库,集成于消费方进程,消费方通过他来获取到服务提供方的地址.
三、官方地址
https://github.com/Netflix/ribbon
四、Ribbon的初始化配置
1、修改microservicecloud-consumer-dept-80工程
修改pom文件
<!-- 将微服务provider侧注册进eureka -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
修改yml文件 添加
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/ #向服务中心注册自己
register-with-eureka: false
对configBean进行新注解@LoadBalanced获得Rest时加入Ribbon的配置
@Configuration
public class ConfigBean {
@Bean
@LoadBalanced //注解表明这个restRemplate开启负载均衡的功能。
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
}
主启动类ConSumeAppStart_80添加@EnableEurekaClient
@SpringBootApplication
@EnableEurekaClient
public class ConSumeAppStart {
public static void main(String[] args) {
SpringApplication.run(ConSumeAppStart.class);
}
}
修改DeptController客户端访问类
@RestController
public class DeptController { //private static final String REST_URL_PREFIX = "http://localhost:8001";
private static final String REST_URL_PREFIX = "http://MICROSERVICECLOUD-DEPT";
//完成真正的通过微服务名字从eureka上找到并访问
/**
* 使用 使用restTemplate访问restful接口非常的简单粗暴无脑。 (url, requestMap,
* ResponseBean.class)这三个参数分别代表 REST请求地址、请求参数、HTTP响应转换被转换成的对象类型。
*/
@Autowired
private RestTemplate restTemplate;
@RequestMapping(value = "/consumer/dept/add")
public boolean add(Dept dept)
{
return restTemplate.postForObject(REST_URL_PREFIX + "/dept/addDept", dept, Boolean.class);
} @RequestMapping("/findAll")
public List<Dept> findAll() {
return restTemplate.getForObject(REST_URL_PREFIX + "/dept/findAll",List.class);
}
}
先启动3个eureka集群后,在启动microservicecloud-config-dept-client-8001并注册进eureka

启动ConSumeAppStart_80
测试 访问地址:http://localhost:80/findAll
效果

五、Ribbon负载均衡
1、架构说明图

Ribbon在工作分成2步
第一步:先选择EurekaServer,它优先选择在同一个区域负载较少的server
第二步:再根据用户指定策略,在从server取到的服务注册列表中选择一个地址.
其中Ribbon提供了多种策略:比如轮询,随机和根据时间响应加权
六、创建提供者多服务
参考microservicecloud-provider-dept-8001新建2份,分别命名为8002,8003
新建8002/8003 数据库,各自微服务分别连各自的数据库clouddb02/clouddb03
修改8002/8003各自的yml
8002 yml
server:
port: 8002
mybatis:
config-location: classpath:mybatis/mybatis.cfg.xml # mybatis配置文件所在路径
type-aliases-package: com.yehui.entity # 所有Entity别名类所在包
mapper-locations: classpath:mybatis/mapper/**/*.xml # mapper映射文件
#应用名称
spring:
application:
name: microservicecloud-dept
datasource:
type: com.alibaba.druid.pool.DruidDataSource # 当前数据源操作类型
driver-class-name: org.gjt.mm.mysql.Driver # mysql驱动包
url: jdbc:mysql://localhost:3306/clouddb02 # 数据库名称
username: root
password: root
dbcp2:
min-idle: 5 # 数据库连接池的最小维持连接数
initial-size: 5 # 初始化连接数
max-total: 5 # 最大连接数
max-wait-millis: 200 # 等待连接获取的最大超时时间
eureka:
client: #客户端注册进eureka服务列表内
service-url:
defaultZone: http://localhost:7001/eureka/,http://localhost:7002/eureka/,http://localhost:7003/eureka/
###是否向注册中心注册自己
register-with-eureka: true
###是否需要从eureka上获取注册信息
fetch-registry: true instance:
instance-id: providerdept_8001 #自定义服务名称
prefer-ip-address: true #访问路径可以显示IP地址
#信息的描述
info:
app.name: atguigu-microservicecloud
company.name: www.atguigu.com
build.artifactId: $project.artifactId$
build.version: $project.version$
8003yml
server:
port: 8003
mybatis:
config-location: classpath:mybatis/mybatis.cfg.xml # mybatis配置文件所在路径
type-aliases-package: com.yehui.entity # 所有Entity别名类所在包
mapper-locations: classpath:mybatis/mapper/**/*.xml # mapper映射文件
spring:
application:
name: microservicecloud-dept
datasource:
type: com.alibaba.druid.pool.DruidDataSource # 当前数据源操作类型
driver-class-name: org.gjt.mm.mysql.Driver # mysql驱动包
url: jdbc:mysql://localhost:3306/clouddb03 # 数据库名称
username: root
password: root
dbcp2:
min-idle: 5 # 数据库连接池的最小维持连接数
initial-size: 5 # 初始化连接数
max-total: 5 # 最大连接数
max-wait-millis: 200 # 等待连接获取的最大超时时间 eureka:
client: #客户端注册进eureka服务列表内
service-url:
defaultZone: http://localhost:7002/eureka/,http://localhost:7003/eureka/,http://localhost:7001/eureka/
instance:
instance-id: providerdept_8003 #自定义服务名称
prefer-ip-address: true #访问路径可以显示IP地址
#信息的描述
info:
app.name: atguigu-microservicecloud
company.name: www.atguigu.com
build.artifactId: $project.artifactId$
build.version: $project.version$
备注
端口
数据库链接 jdbc:mysql://localhost:3306/clouddb01
对外暴露的统一的服务实例名

启动3个eureka集群配置区
启动3个Dept微服务并各自测试通过
http://localhost:8003/dept/findAll
http://localhost:8001/dept/findAll
http://localhost:8002/dept/findAll
启动ConSumeAppStart_80
客户端通过Ribbon完成负载均衡并访问上一步的Dept微服务

上图有三个消费者
注意观察看到返回的数据的数据库的不同

从上面可以得到:Ribbon其实就是一个软负载均衡的客户端组件,他可以和其他所需求请求的客户端结合使用,和eureka结合只是其中的一个实例
七、Ribbon核心组件IRule
1、IRule算法
IRule:根据特点算法中从服务列表中选取一个要访问的服务
RoundRobinRule:轮询算法
RandomRule随机算法
AvailabilityFilteringRule:会先过滤由于多次访问故障而处于断路器跳闸状态的服务,还有并发的连接数量超过阈值的服务,然后对剩余的服务列表按照轮询策略进行访问
WeightedResponseTimeRule:根据平均响应的时间计算所有服务的权重,响应时间越快服务权重越大被选中的概率越高,刚启动时如果统计信息不足,则使用RoundRobinRule策略,等统计信息足够会切换到WeightedResponseTimeRule
RetryRule:先按照RoundRobinRule的策略获取服务,如果获取失败则在制定时间内进行重试,获取可用的服务。
BestAviableRule:会先过滤掉由于多次访问故障而处于断路器跳闸状态的服务,然后选择一个并发量最小的服务
ZoneAvoidanceRule:默认规则,符合判断server所在区域的性能和server的可用性选择服务器
RetryRule:先根据RoundRonbinRule的策略获取服务,如果获取服务失败则在指定时间内会进行重试,获取可用的服务
访问地址:https://github.com/Netflix/ribbon

config类
@Bean
public IRule getRule(){
return new RandomRule(); //使用随机的算法替换默认的轮询算法
}
测试访问:http://localhost:80/findAll
2、Ribbon自定义
修改microservicecloud-consumer-dept-80
主启动类添加@RibbonClient
在启动该微服务的时候就能去加载我们自定义Ribbon配置类,从而使配置生效,形如:
@RibbonClient(name = "MICROSERVICECLOUD-DEPT",configuration = MyRule.class)
注意细节

步骤:
新建一个MyRule类
@Configuration
public class MyRule {
@Bean
public IRule getRule(){
return new RoundRobinRule(); //使用使用轮询算法
}
}
修改主启动类新增@RibbonClient注解
@SpringBootApplication
@EnableEurekaClient //表明自己是一个eurekaclient.
@RibbonClient(name = "MICROSERVICECLOUD-DEPT",configuration = MyRule.class)
public class ConSumeAppStart_80 { public static void main(String[] args) {
SpringApplication.run(ConSumeAppStart_80.class);
}
}
测试http://localhost:80/findAll
3、自定义规则深度解析
问题:依旧轮询策略,但是加上新需求,每个服务要求被调用5次.也即
以前是每台机器一次,现在是每台机器5次
解析源码:https://github.com/Netflix/ribbon/blob/master/ribbon-
loadbalancer/src/main/java/com/netflix/loadbalancer/RandomRule.java
参考源码修改为我们的需求需的MyRole_YH.java
更新中
4、使用DiscoveryClient实现本地负载均衡
编写controller
@RestController
public class DeptController { //获取服务注册信息
@Autowired
private DiscoveryClient discoveryClient; @Autowired
private RestTemplate restTemplate; @RequestMapping("/find")
public List<Dept> find(){
List<ServiceInstance> instances = discoveryClient.getInstances("microservicecloud-dept");
int instacesSize = instances.size();
int index = num%instacesSize;
num++;
String url = instances.get(index).getUri().toString();
return restTemplate.getForObject(url + "/dept/findAll",List.class);
}
}
congig类
@Configuration
public class ConfigBean {
@Bean
//@LoadBalanced 这个注解不需要了
public RestTemplate getRestTemplate(){
return new RestTemplate();
} }
测试
5、Ribbon与Nginx区别
客户端负载均衡器
在SpringCloud中Ribbon负载均衡客户端,会从eureka注册中心服务器端上获取服务注册信息列表,缓存到本地。
让后在本地实现轮训负载均衡策略。
服务器端负载均衡Nginx
nginx是客户端所有请求统一交给nginx,由nginx进行实现负载均衡请求转发,属于服务器端负载均衡。
既请求有nginx服务器端进行转发。
客户端负载均衡Ribbon
Ribbon是从eureka注册中心服务器端上获取服务注册信息列表,缓存到本地,让后在本地实现轮训负载均衡策略。
既在客户端实现负载均衡。
应用场景的区别:
Nginx适合于服务器端实现负载均衡 比如Tomcat ,Ribbon适合与在微服务中RPC远程调用实现本地服务负载均衡,比如Dubbo、SpringCloud中都是采用本地负载均衡。
Ribbon负载均衡(四)的更多相关文章
- springcloud(十四)、ribbon负载均衡策略应用案例
一.eureka-server服务中心项目不再创建 二.eureka-common-empdept公共组件项目不再掩饰 三.创建eureka-client-provider-empdept-one提供 ...
- 四. Ribbon负载均衡服务调用
1. 概述 1.1 Ribbon是什么 SpringCloud Ribbon是基于Netflix Ribbon实现的一套客户端,是负载均衡的工具. Ribbon是Netflix发布的开源项目,主要功能 ...
- 四(2)、springcloud之Ribbon负载均衡
2.Ribbon负载均衡 Ribbon在工作时分成两步第一步先选择 EurekaServer ,它优先选择在同一个区域内负载较少的server. 第二步再根据用户指定的策略,在从server取到的 ...
- SpringCloud之Ribbon负载均衡配置
一.负载均衡解决方案分类及特征 业界主流的负载均衡解决方案有: 1.1 集中式负载均衡 即在客户端和服务端之间使用独立的负载均衡设施(可以是硬件,如F5, 也可以是软件,如nginx), 由该设施负责 ...
- spring cloud学习笔记二 ribbon负载均衡
Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为.为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求.Ribb ...
- Spring Cloud06: Ribbon 负载均衡
一.使用背景 前面的学习中,我们已经使用RestTemplate来实现了服务消费者对服务提供者的调用,如果在某个具体的业务场景下,对某个服务的调用量突然大幅提升,这个时候就需要对该服务实现负载均衡以满 ...
- SpringCloud系列——Ribbon 负载均衡
前言 Ribbon是一个客户端负载均衡器,它提供了对HTTP和TCP客户端的行为的大量控制.我们在上篇(猛戳:SpringCloud系列——Feign 服务调用)已经实现了多个服务之间的Feign调用 ...
- Spring Cloud微服务Ribbon负载均衡/Zuul网关使用
客户端负载均衡,当服务节点出现问题时进行调节或是在正常情况下进行 服务调度.所谓的负载均衡,就是当服务提供的数量和调用方对服务进行 取舍的调节问题,在spring cloud中是通过Ribbon来解决 ...
- SpringCloud系列五:Ribbon 负载均衡(Ribbon 基本使用、Ribbon 负载均衡、自定义 Ribbon 配置、禁用 Eureka 实现 Ribbon 调用)
1.概念:Ribbon 负载均衡 2.具体内容 现在所有的服务已经通过了 Eureka 进行了注册,那么使用 Eureka 注册的目的是希望所有的服务都统一归属到 Eureka 之中进 行处理,但是现 ...
随机推荐
- Pascal小游戏 俄罗斯方块怀旧版
俄罗斯方块怀旧版(注释版) {$APPTYPE GUI}{$MODE DELPHI}program WinPiece; usesWindows; constAppName = 'WinPiece';p ...
- 一个初学者的辛酸路程-前端js
内容回顾: 1.CSS的基本概念: 层叠样式表. 2.CSS的三种书写方式 ① 行内样式 <div style="color: red;">sdfdsf</div ...
- c# asp.net 中使用token验证
基于token的鉴权机制类似于http协议也是无状态的,它不需要在服务端去保留用户的认证信息或者会话信息.这就意味着基于token认证机制的应用不需要去考虑用户在哪一台服务器登录了,这就为应用的扩展提 ...
- windows auto activate
目前所支持的windows镜像都是未激活状态,未激活状态下很多功能无法使用. 以后将要实现的功能是,windows虚机启动后,网络正常后能与KMS服务器通信,自动激活key 目前想到两种办法: 1.b ...
- Qt(1)
Qt Qt开发图形界面软件,可以跨win.linux.mac平台.移动端,使用c++开发 Qt采用所见即所得的UI设计(UI设计和代码是联动的),GUI界面编辑信号和槽,由开发环境自动生成c++代码, ...
- CentOS6.5下搭建LAMP环境(源码编译方式)
CentOS 6.5安装配置LAMP服务器(Apache+PHP5+MySQL) 学习PHP脚本编程语言之前,必须先搭建并熟悉开发环境,开发环境有很多种,例如LAMP ,WAMP,MAMP等.这里我介 ...
- android 使用LruCache缓存网络图片
加载图片,图片如果达到一定的上限,如果没有一种合理的机制对图片进行释放必然会引起程序的崩溃. 为了避免这种情况,我们可以使用Android中LruCache来缓存下载的图片,防止程序出现OOM. ...
- class内部处理
class A { public: int foo( ) { return val ; } static int staFun( ) { return staVal ; } static int st ...
- mssql 格式化字符串 /时间 年月日时分秒
比如:1 想格式化 000001,100 格式化为000100: 思路是这样的 1000000 +格式化的数字 取后6位: select right(cast(power(10,6) as var ...
- Citrix NetScaler HA(高可用性)解析
Citrix NetScaler HA(高可用性)解析 来源 https://www.iyunv.com/thread-172259-1-1.html 1.1 NetScaler高可用概述 我 ...