Sentinel(流控模式:直接关联链路,流控效果:直接预热排队)

Sentinel能够对流量进行控制,主要是监控应用的QPS流量或者并发线程数等指标,如果达到指定的阈值时,就会被流量进行控制,以避免服务被瞬时的高并发流量击垮,保证服务的高可靠性。

1.流控模式:

直接模式测试案例

表示1秒钟内查询1次就是OK,若超过次数1,就直接-快速失败,报默认错误。

测试结果

关联模式测试案例 

当关联的资源到达阈值,就限流自己

测试案例:当关联资源/testB的qps阀值超过1时,就限流/testA的Rest访问地址,当关联资源到阈值后限制配置好的资源名,B惹事,A挂了

使用jmeter对testB进行高并发访问  导致A挂了

测试结果:

链路模式测试案例

当不同链路的请求对同一个目标访问时,实施针对性的不同限流措施

eg:C请求访问限流 D请求访问不限流

添加yml配置:

新建测试业务类:
package com.wen.cloud.service;

import com.alibaba.csp.sentinel.annotation.SentinelResource;
import org.springframework.stereotype.Service;
@Service
public class FlowLimitService
{
    @SentinelResource(value = "common")
    public void common()
    {
        System.out.println("------FlowLimitService come in");
    }
}
/**流控-链路演示demo
     * C和D两个请求都访问flowLimitService.common()方法,阈值到达后对C限流,对D不管
     */
    @Resource
    private FlowLimitService flowLimitService;

    @GetMapping("/testC")
    public String testC()
    {
        flowLimitService.common();
        return "------testC";
    }
    @GetMapping("/testD")
    public String testD()
    {
        flowLimitService.common();
        return "------testD";
    }
sentinel配置

说明:C和D两个请求都访问flowLimitService.common()方法,对C限流,对D不管

2.流控效果:

快速失败

直接失败,抛出异常。

预热(WarmUp)

限流-冷启动

当流量突然增大时,让系统从空闲状态到繁忙状态的切换时间更长一些

计算公式:阈值÷冷却因子coldFactor(默认为3),经过预热时长后才会到达阈值。

测试案例:

案例,单机阈值为10,预热时长设置5秒。

系统初始化的阈值为10 / 3 约等于3,即单机阈值刚开始为3(我们人工设定单机阈值是10,sentinel计算后QPS判定为3开始);

然后过了5秒后阀值才慢慢升高恢复到设置的单机阈值10,也就是说5秒钟内QPS为3,过了保护期5秒后QPS为10        

测试结果

应用场景:

秒杀系统在开启的瞬间,会有很多流量上来,很有可能把系统打死,预热方式就是把为了保护系统,可慢慢的把流量放进来,慢慢的把阈值增长到设置的阈值。

排队等待

测试案例:
@GetMapping("/testE")
    public String testE(){
        System.out.println(System.currentTimeMillis()+"      testE,排队等待");
        return "------testE";
    }

按照单机阈值,一秒钟通过一个请求,10秒后的请求作为超时处理,放弃

jmeter测试  一秒访问二十次

测试结果:

请求只捕捉了十一个请求,十秒后的请求都放弃

  • 29
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值