客户端负载均衡: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. HTTP深入浅出 http请求完整过程

    HTTP(HyperText Transfer Protocol)是一套计算机通过网络进行通信的规则.计算机专家设计出HTTP,使HTTP客户(如Web浏览器)能够从HTTP服务器(Web服务器)请求 ...

  2. Java(16)接口

    一.接口:特殊的抽象类 1.1 语法 public interface 接口名 extends 接口1,接口2{ //1.常量 //2.抽象方法 } 1.2 特点 a.用interface修饰 b.接 ...

  3. python selenium 最简单示例

    使用 pip 安装  selenium 下载 chromedriver,添加在PATH中 # -*- coding: utf-8 -*- from selenium import webdriver ...

  4. Ubuntu18.04环境下melodic安装gmapping

    Ubuntu18.04 环境下melodic中很多包没有提供sudo apt install的安装方式,需要通过源代码安装,安装方法如下: 1.先安装依赖库: sudo apt--dev sudo a ...

  5. JS+CSS实现弹出全屏灰黑色透明遮罩效果的方法

    本文实例讲述了js+CSS实现弹出一个全屏灰黑色透明遮罩效果的方法.分享给大家供大家参考.具体分析如下: 在众多的网站都有这样的效果,当进行一定的操作之后,会弹出一个灰黑色的半透明的遮罩,在上面可以操 ...

  6. ueditor复制文本有多余的空行问题

    今天从ueditor中复制文本,粘贴到记事本中发现每一行后面都多了一个空行. Ueditor中的文本如图: 本来只有三行,全选复制所有内容,再粘贴到记事本中发现有每一行文本后面都有多余的空行: 如果我 ...

  7. Python 中写一个装饰器实现限制频率访问

    1.思路: 首先要在装饰器中确定访问的方法名, 第一次可以访问成功,之后要在规定的时间(变量)之后才可以访问. 初始应该有一个变量为0;访问成功之后把当前的时间赋值给这个变零. 这样再次访问时把当前的 ...

  8. 使用Promise发送多个异步请求, 全部完成后再执行

    const datas = idList .map(id => url+'/id') .map(url => fetch(url).then(res => res.json())); ...

  9. git知识总结-3.gitignore文件说明

    1.前言 一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表. 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等. 在这种情况下,我们可以创建一个名 ...

  10. sql 常见错误总结

    1.根据一张表更新另一张表的数据. . 写法轻松,更新效率高: update table1 set field1=table2.field1, field2=table2.field2 from ta ...