Sentinel限流熔断应用实践

目录

1.Sentinel简介

1.1 背景分析

1.2 Sentinel概述

1.3 安装Sentinel服务 

1.4 访问Sentinal服务

2.Sentinel监控入门

2.1 概述

2.2 准备工作

2.3 Sentinel限流入门实践

3.Sentinel流控规则分析

3.1阈值类型

3.2设置限流模式

限流,浏览器自定义名字:

4.Sentinel降级应用实践

4.1概述

4.2准备工作

4.3Sentinel降级入门

5.Sentinel热点规则分析(重点)

5.1概述

5.2快速入门

5.3特定参数设计

6. Sentinel系统规则

6.1概述

6.2快速入门

7.Sentinel授权规则

7.1概述

7.2快速入门


 

1.Sentinel简介

1.1 背景分析

        在我们日常生活中,经常会在淘宝、天猫、京东、拼多多等平台上参与商品的秒杀、抢购以及一些优惠活动,也会在节假日使用12306 手机APP抢火车票、高铁票,甚至有时候还要帮助同事、朋友为他们家小孩拉投票、刷票,这些场景都无一例外的会引起服务器流量的暴涨,导致网页无法显示、APP反应慢、功能无法正常运转,甚至会引起整个网站的崩溃。
        我们如何在这些业务流量变化无常的情况下,保证各种业务安全运营,系统在任何情况下都不会崩溃呢?我们可以在系统负载过高时,采用限流、降级和熔断,三种措施来保护系统,由此一些流量控制中间件诞生。例如Sentinel。

1.2 Sentinel概述

        Sentinel (分布式系统的流量防卫兵) 是阿里开源的一套用于服务容错的综合性解决方案。它以流量为切入点, 从流量控制、熔断降级、系统负载保护等多个维度来保护服务的稳定性。
        Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景, 例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。

Sentinel核心分为两个部分:

  1. 核心库(Java 客户端):能够运行于所有 Java 运行时环境,同时对Dubbo /Spring Cloud 等框架也有较好的支持。
  2. 控制台(Dashboard):基于 Spring Boot 开发,打包后可以直接运行。

1.3 安装Sentinel服务 

Sentinel 提供一个轻量级的控制台, 它提供机器发现、单机资源实时监控以及规则管理等功能。

sentinel下载网址,下载Jar包(可以存储到一个sentinel目录)
 

在sentinel对应目录,打开命令行(cmd),启动运行sentinel

java -Dserver.port=8180 -Dcsp.sentinel.dashboard.server=localhost:8180 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.1.jar

1.4 访问Sentinal服务

打开浏览器访问:默认用户名和密码:sentinal

 

2.Sentinel监控入门

2.1 概述

        我们系统中的数据库连接池,线程池,nginx的瞬时并发等在使用时都会给定一个限定的值,这本身就是一种限流的设计。限流的目的防止恶意请求流量、恶意攻击,或者防止流量超过系统峰值。

2.2 准备工作

第一步:Sentinel 应用于服务提供方(sca-provider),在服务提供方添加依赖

 <!--添加sentinel依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>

第二步:打开服务提供方配置文件bootstrap.yml,添加sentinel配置

spring:
  cloud:
    sentinel:
      transport:
         dashboard: localhost:8180 # 指定sentinel控制台地址。

第三步:创建一个用于演示限流操作的Controller对象

package com.jt.provider.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/provider")
public class ProviderSentinelController {

    @GetMapping("/sentinel01")
    public String doSentinel01(){
        return "test sentinel 01";

    }

}

 第四步:启动sca-provider服务,然后对指定服务进行访问

第五步:刷新sentinel 控制台,实时监控信息 

        Sentinel的控制台其实就是一个SpringBoot编写的程序,我们需要将我们的服务注册到控制台上,即在微服务中指定控制台的地址,并且还要在消费端开启一个与sentinel控制台传递数据端的端口,控制台可以通过此端口调用微服务中的监控程序来获取各种信息。

2.3 Sentinel限流入门实践

        我们设置一下指定接口的流控(流量控制),QPS(每秒请求次数)单机阈值为1,代表每秒请求不能超出1次,要不然就做限流处理,处理方式直接调用失败。

第一步:选择要限流的链路

第二步:设置限流策略

第三步:反复刷新访问你的服务,检测是否有限流信息输出

3.Sentinel流控规则分析

3.1阈值类型

  1. QPS(Queries Per Second):当调用相关url对应的资源时,QPS达到单机阈值时,就会限流。
  2. 线程数:当调用相关url对应的资源时,线程数达到单机阈值时,就会限流。

3.2设置限流模式

Sentinel的流控模式代表的流控的方式,默认【直接】,还有关联,链路。

  • 直接模式

Sentinel默认的流控处理就是【直接->快速失败】

  •  关联模式

        当关联的资源达到指定阈值,就限流自己。例如设置了关联资源为ur2时&

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值