客户端负载均衡:Spring Cloud Ribbon

一、负载均衡概念

负载均衡在系统架构中是一个非常重要,并且是不得不去实施的内容。因为负载均衡对系统的高可用性、

网络压力的缓解和处理能力的扩容的重要手段之一。通常所说的负载均衡指的是服务端负载均衡,分为

硬件负载均衡和软件负载均衡,服务端负载均衡架构方式:

负载均衡都会维护一个下挂可用的服务端清单,并通过心跳检测来剔除故障的服务端节点。

客户端负载均衡与服务端负载均衡最大的不同点在于服务清单的位置,在客户端负载均衡

中,所有的客户端节点都维护着自己要访问的服务端清单,这些清单都来自于服务注册中心。  

二、快速入门

代码详情见:https://gitee.com/tangjiapi/RibbonDemon.git

三、Spring Cloud Ribbon 实战

1.Ribbon负载均衡策略与自定义配置

在Ribbon中有丰富的负载均衡策略可供选择:

策略类                   命名                       描述

RandomRule             随机策略                   随机选择server

RoundRobinRule         轮询策略                   按顺序选择server(默认策略)

RetryRule              重试策略                   在一个配置时间段内当选择server不成功,则一直尝试选择一个可用的server

BestAvailableRule      最低并发策略               逐个考察server,如果server断路器打开,则忽略,在选择其中并发链接最低的server

AvailabilityFilterRule 可用过滤策略               过滤掉一直链接失败并被标记为circuit tripped的server,过滤掉那些高并发链接的server(active connections超过配置的阈值)

ResponseTimeWeightRule 响应时间加权策略           根据server的响应时间分配权重。响应时间越长,权重越低,被选择到的概率就越低

ZoneAvoidanceRule      区域权衡策略               综合判断server所在区域的性能和server的可用轮询选择server,并且判定一个AWS Zonede的运行性能是否可用,剔除不可用的Zone中的所有Server.

1)全局策略设置

@Configuration
public class TestConfiguration {
@Bean
public IRule ribbonRule() {
return new RandomRule();
}
}

凡是通过ribbon的请求都会按照配置的规则进行。

2)基于注解的策略设置

/**
* 声明,用于排除
* @author Tang Jiujia
* @since 2019-03-26
*/
public @interface AvoidScan {
}
@Configuration
@AvoidScan
public class TestConfiguration {
@Autowired
IClientConfig config;
@Bean
public IRule ribbonRule(IClientConfig config) {
return new RandomRule();
}
}
@SpringBootApplication
@EnableDiscoveryClient
@RibbonClient(name = "client-a", configuration = TestConfiguration.class)
//让Spring不去扫描@AvoidScan注解的类,因为我们的配置是对单个服务源生效,
// 所以不能应用于全局,如果不排除会报错
@ComponentScan(excludeFilters = {@ComponentScan.Filter
(type = FilterType.ANNOTATION, value = {AvoidScan.class})})
public class RibbonLoadbalancerApplication { public static void main(String[] args) {
SpringApplication.run(RibbonLoadbalancerApplication.class, args);
} /**
* 用于负载均衡
* */
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
}

3)基于配置文件的策略设置

client-a:
ribbon:
NFLoadBalanceRuleClassName: com.netflix.loadbalancer.RandomRule

2.Ribbon超时与重试

F版中的Ribbon重试机制是默认开启的,需要添加对于超时时间与重试策略的配置:

client-a:
ribbon:
ConnectTimeout: 30000
ReadTimeout: 30000
MaxAutoRetries: 1 #对第一次请求的服务的重试次数
MaxAutoRetriesNextServer: 1 #要重试的下一个服务的最大数量
OkToRetryOnAllOperations: true

3.Ribbon的饥饿加载

Ribbon在进行客户端负载均衡时并不是在启动时就加载上下文,而是在实际请求时才去

创建,因此这个特性往往会让我们第一次调用时显得疲软乏力,严重时会引起调用超时。

所有我们可以通过指定Ribbon客户端的名称来开启饥饿加载,即在启动的时候就加载所有

配置项的应用程序上下文。

ribbon:
eager-load:
enabled: true
clients: client-a, client-b, client-c

4.利用配置文件自定义Ribbon客户端

使用配置文件的优先级最高,高于注解和源码中的bean

5.Ribbon脱离Eureka使用

默认情况下,Ribbon客户端会从Eureka注册中心读取服务注册列表,来达到一种

动态的负载均衡。但如果Eureka是一个供很多人使用的公共注册中心,极可能产生

服务侵入性问题,所以就不要从Eureka读取服务列表了,而应该在Ribbon客户端自行指定

服务地址,让Ribbon脱离Eureka来使用。

首先,需要在Ribbon中禁用Eureka功能:

ribbon:
eureka:
enable: false

然后对源服务设定地址列表:

client:
ribbon:
listOfServers: http://localhost:, http://localhost:

Spring Cloud微服务笔记(四)客户端负载均衡:Spring Cloud Ribbon的更多相关文章

  1. Spring Cloud Ribbon---微服务调用和客户端负载均衡

    前面分析了Eureka的使用,作为服务注册中心,Eureka 分为 Server 端和 Client 端,Client 端作为服务的提供者,将自己注册到 Server 端,Client端高可用的方式是 ...

  2. Spring Cloud 微服务六:调用链跟踪Spring cloud sleuth +zipkin

    前言:随着微服务系统的增加,服务之间的调用关系变得会非常复杂,这给运维以及排查问题带来了很大的麻烦,这时服务调用监控就显得非常重要了.spring cloud sleuth实现了对分布式服务的监控解决 ...

  3. Spring Cloud微服务笔记(三)服务治理:Spring Cloud Eureka快速入门

    服务治理:Spring Cloud Eureka 一.服务治理 服务治理是微服务架构中最为核心和基础的模块,它主要用来实现各个微服务实例的自动化注册与发现. 1.服务注册: 在服务治理框架中,通常会构 ...

  4. Spring Cloud入门教程(二):客户端负载均衡(Ribbon)

    对于大型应用系统负载均衡(LB:Load Balancing)是首要被解决一个问题.在微服务之前LB方案主要是集中式负载均衡方案,在服务消费者和服务提供者之间又一个独立的LB,LB通常是专门的硬件,如 ...

  5. 【SpringCloud微服务实战学习系列】客户端负载均衡Spring Cloud Ribbon

    Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现.通过Spring Cloud的封装,可以让我们轻松地将面向服务的RES模板 ...

  6. Spring Cloud官方文档中文版-客户端负载均衡:Ribbon

    官方文档地址为:http://cloud.spring.io/spring-cloud-static/Dalston.SR2/#_spring_cloud_netflix 文中例子我做了一些测试在:h ...

  7. Spring Cloud微服务笔记(五)Feign

    Feign 一.Feign概述 Feign是一个声明式的Web Service客户端.在Spring Cloud 中使用Feign,可以做到 使用HTTP请求访问远程服务,就像调用本地方法一样,同时它 ...

  8. Spring Cloud微服务笔记(二)Spring Cloud 简介

    Spring Cloud 简介 Spring Cloud的设计理念是Integrate Everything,即充分利用现有的开源组件, 在它们之上设计一套统一的规范/接口使它们能够接入Spring ...

  9. Spring Cloud微服务笔记(一)微服务概念

    微服务概念 一.什么是微服务架构 微服务,是一个小的.松耦合的分布式服务. 为什么需要微服务: 1)单体系统部署在一个进程中,修改了一个小功能,为了部署上线就会影响其他功能. 2)单体应用各个功能模块 ...

随机推荐

  1. JavaScript之iframe页面间通信

    [1] iframe父子页面间通信 1.相互调用对方的方法 |> 子级页面调用父级页面 window.parent.父级页面方法(args) |> 父级页面调用子级页面 document. ...

  2. kai linux安装搜狗输入法以及更新源地址

    需要去搜狗官网下载linux版的输入法,根据自己的系统选择多少位进行下载. 首先执行如下命令:dpkg -i 输入法包名,这时会报错,会报没有安装依赖包,这时需要执行apt-get install - ...

  3. 第三周四则运算辅助(CAI)结对项目需求文档

    小学四则运算辅助(CAI) UI需求: 目的:让更对的小学生能学到更多的知识,提高做题的效率. 背景:该系统应用于小学生数学算术题的出题,判断对错以及错题本,该系统为解决家长每天为孩子出题的不便而解决 ...

  4. java错误分类

    IllegalArgumentException 回直接crashError

  5. stylus 实践

    音乐分享: Broken Back - <Halcyon Birds> —————————————————————————————————————————————————————————— ...

  6. story 泄露服务器libc版本

    记录下学到的姿势,利用信息泄露得到服务器libc 至少两个函数偏移,利用libc-databse得到服务器libc版本 传送门 泄露脚本如下 from pwn import * context.log ...

  7. jenkins主要目录用途

    主目录 除了Jenkins的WAR包所在目录,Jenkins还有一个更重要的目录——Jenkins的所有重要数据都存放在这个独立的目录中,称为Jenkins主目录,它的默认位置是在当前用户根目录的隐藏 ...

  8. Python——字符串

    p ython——字符串 ①加法 连接两个字符串 ②乘法  复制字符串 python——转义字符 \n 换行 \' 单引号 \'' 双引号 \\ 反斜杠 raw字符串:无视转义字符   转义: 字符串 ...

  9. 详解PROTOCOL BUFFERS

    1. 前言 Protocal Buffers是google推出的一种序列化协议.由于它的编码和解码的速度,已经编码后的大小控制的较好,因此它常常被用在RPC调用中,传递参数和结果.比如gRPC. Pr ...

  10. OpenCV-Python:车道检测

    任务: 一共要完成两项任务: 1. 在所提供的公路图片上检测出车道线并标记 2. 在所提供的公路视频上检测出车道线并标记 方案: 要检测出当前车道,就是要检测出左右两条车道直线.由于无人车一直保持在当 ...