微服务保护-流量控制1

请添加图片描述
个人名片:

博主:酒徒ᝰ.
个人简介沉醉在酒中,借着一股酒劲,去拼搏一个未来。
本篇励志三人行,必有我师焉。

请添加图片描述
本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》,SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 点击观看

目录

  • 二、流量控制
    • 1. 簇点链路
    • 2. 快速入门
    • 3. 流控模式

二、流量控制

雪崩问题虽然有四种方案,但是限流是避免服务因突发的流量而发生故障,是对微服务雪崩问题的预防。我们先学习这种模式。

1. 簇点链路

当请求进入微服务时,首先会访问DispatcherServlet,然后进入Controller、Service、Mapper,这样的一个调用链就叫做簇点链路。簇点链路中被监控的每一个接口就是一个资源

默认情况下sentinel会监控SpringMVC的每一个端点(Endpoint,也就是controller中的方法),因此SpringMVC的每一个端点(Endpoint)就是调用链路中的一个资源。

例如,我们刚才访问的order-service中的OrderController中的端点:/order/{orderId}

微服务保护-流量控制1_第1张图片

流控、熔断等都是针对簇点链路中的资源来设置的,因此我们可以点击对应资源后面的按钮来设置规则:

  • 流控:流量控制
  • 降级:降级熔断
  • 热点:热点参数限流,是限流的一种
  • 授权:请求的权限控制

2. 快速入门

  1. 示例

点击资源/order/{orderId}后面的流控按钮,就可以弹出表单.

微服务保护-流量控制1_第2张图片

表单中可以填写限流规则。

微服务保护-流量控制1_第3张图片
2. 案例:

给 /order/{orderId}这个资源设置流控规则,QPS不能超过 5,然后测试。

1)首先在sentinel控制台添加限流规则
微服务保护-流量控制1_第4张图片

2)利用jmeter测试

在课前资料中找到

在这里插入图片描述

直接解压,进入bin目录,找到jmeter.bat双击

微服务保护-流量控制1_第5张图片

课前资料提供了编写好的Jmeter测试样例:
打开jmeter,导入课前资料提供的测试样例:

在这里插入图片描述

选中流控入门,QPS<5右键运行:

微服务保护-流量控制1_第6张图片

结果:

微服务保护-流量控制1_第7张图片

可以看到,成功的请求每次只有5个。(结果不一定完全符合。可以多试几次)

3. 流控模式

在添加限流规则时,点击高级选项,可以选择三种流控模式

  • 直接:统计当前资源的请求,触发阈值时对当前资源直接限流,也是默认的模式
  • 关联:统计与当前资源相关的另一个资源,触发阈值时,对当前资源限流
  • 链路:统计从指定链路访问到本资源的请求,触发阈值时,对指定链路限流
  1. 快速入门测试的就是直接模式。

  2. 关联模式

关联模式:统计与当前资源相关的另一个资源,触发阈值时,对当前资源限流

使用场景:比如用户支付时需要修改订单状态,同时用户要查询订单。查询和修改操作会争抢数据库锁,产生竞争。业务需求是优先支付和更新订单的业务,因此当修改订单业务触发阈值时,需要对查询订单业务限流。

案例

  1. 在OrderController新建两个端点:/order/query和/order/update,无需实现业务
  2. 配置流控规则,当/order/ update资源被访问的QPS超过5时,对/order/query请求限流

1)定义/order/query端点和/order/update端点,模拟订单查询和更新

@GetMapping("/query")
public String queryOrder() {
    return "查询订单成功";
}

@GetMapping("/update")
public String updateOrder() {
    return "修改订单成功";
}

重启orderApplication服务,查看sentinel控制台的簇点链路:
(访问前需要先在浏览器进行一次页面访问才可以查询到簇点链路。)

微服务保护-流量控制1_第8张图片

3)配置流控规则

对哪个端点限流,就点击哪个端点后面的按钮。我们是对订单查询/order/query限流.
在表单中填写流控规则:

微服务保护-流量控制1_第9张图片

4)在Jmeter测试

选择《流控模式-关联》:

微服务保护-流量控制1_第10张图片

可以看到1000个用户,100秒,因此QPS为10,超过了我们设定的阈值:5

查看http请求:

微服务保护-流量控制1_第11张图片

请求的目标是/order/update,这样这个断点就会触发阈值。
但限流的目标是/order/query,我们在浏览器访问query业务,可以发现:

在这里插入图片描述
确实被限流了。

总结:

满足下面条件可以使用关联模式:

  • 两个有竞争关系的资源
  • 一个优先级高,一个优先级低
  1. 链路模式

链路模式:只针对从指定链路访问到本资源的请求做统计,判断是否超过阈值。

案例

需求:有查询订单和创建订单业务,两者都需要查询商品。针对从查询订单进入到查询商品的请求统计,并设置限流。
步骤:

  1. 在OrderService中添加一个queryGoods方法,不用实现业务
  2. 在OrderController中,改造/order/query端点,调用OrderService中的queryGoods方法
  3. 在OrderController中添加一个/order/save的端点,调用OrderService的queryGoods方法
  4. 给queryGoods设置限流规则,从/order/query进入queryGoods的方法限制QPS必须小于2

实现:

1)添加查询商品方法

在order-service服务中,给OrderService类添加一个queryGoods方法:
默认情况下,OrderService中的方法是不被Sentinel监控的,需要我们自己通过注解的方式来标注监控的方法,及添加@SentinelResource()

@SentinelResource("goods")
public void QueryGood() {
    System.err.println("查询商品");
}

2)查询订单时,查询商品

在order-service的OrderController中,修改/order/query端点的业务逻辑:

@GetMapping("/query")
public String queryOrder() {
    orderService.queryGoods();
    return "查询订单成功";
}

3)新增订单,查询商品

在order-service的OrderController中,修改/order/save端点,模拟新增订单:

@GetMapping("/save")
public String saveOrder() {
    orderService.queryGoods();
    return "新增订单成功";
}

4)添加配置

链路模式中,是对不同来源的两个链路做监控。但是sentinel默认会给进入SpringMVC的所有请求设置同一个root资源,会导致链路模式失效。

我们需要关闭这种对SpringMVC的资源聚合,修改order-service服务的application.yml文件:

spring:
  cloud:
    sentinel:
      web-context-unify: false

重启服务,访问/order/query和/order/save,可以查看到sentinel的簇点链路规则中,出现了新的资源:

微服务保护-流量控制1_第12张图片

5)添加流控规则

点击任意一个goods资源后面的流控按钮,在弹出的表单中填写下面信息:

微服务保护-流量控制1_第13张图片

只统计从/order/query进入/goods的资源,QPS阈值为2,超出则被限流。

6)Jmeter测试

选择《流控模式-链路》:

一个http请求是访问/order/save:
运行的结果:
微服务保护-流量控制1_第14张图片
完全不受影响。

另一个是访问/order/query:
运行结果:
微服务保护-流量控制1_第15张图片
每次只有2个通过。

总结

流控模式有哪些?
•直接:对当前资源限流
•关联:高优先级资源触发阈值,对低优先级资源限流。
•链路:阈值统计时,只统计从指定资源进入当前资源的请求,是对请求来源的限流

你可能感兴趣的:(SpringCloud,微服务,架构,云原生)