007-spring cloud alibaba之Sentinel限流

sentinel环境搭建

sentinel-dashboard搭建

限流中间件。启动默认接口8080

  • 启动命令:java -jar sentinel-dashboard-1.8.2.jar
  • 访问地址:localhost:8080
  • 访问密码:sentinel/sentinel 如果端口占用,可以在启动命令中增加端口:java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

应用接入sentinel

增加依赖

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

增加配置

yaml 复制代码
server:
  port: 9001

spring:
  application:
    name: user
  cloud:
    discovery:
      server-addr: 127.0.0.1:8848
    sentinel:
      transport:
        dashboard: localhost:8080
        port: 8720
management:
  endpoint:
    web:
      exposure:
        include:'*'

流控

簇点链路->选择需要流控的接口->+流控

  • 资源名:路径,eg:/hello
  • 针对来源:default,默认
  • 阈值类型:QPS/并发线程数。
    • QPS:一秒内请求路径次数
    • 并发线程数:线程数
  • 单机阈值:次数
  • 流控模式:
    • 直接:API达到限流条件时,直接限流
    • 关联:当关联的资源达到阈值时,就限流自己
    • 链路:只记录指定链路上的流量(指定资源从入口资源进来的流量,如果达到阈值,就进行限流)(API级别的针对来源)
  • 流控效果:
    • 快速失败:直接失败,抛异常
    • Wam Up:根据codeFactor(冷加载因子,默认3)的值,从阈值/codeFacotor,经过预热时长,才达到设置的QPS阈值
    • 排队等待:匀速排队,让请求以匀速的速度通过,阈值类型必须设置为QPS,否则无效

流控模式:直接/关联

这两种流控比较简单。直接就是当达到阈值,当前接口不能访问。关联是关联的资源达到阈值就限流自己。举一个关联的例子:下单和支付的关系。下单资源:/createOrder;支付资源:/payOrder。如果要配置关联可以在/payOrder配置一个关联/createOrder的限流。当/createOrder到达阈值,限制/payOrder的接口访问。

流控模式:链路

链路是比较细粒度的限流模式。比如接口A需要调用接口B,接口C需要调用接口B,我们将接口B做为资源。然后配置接口A限流,限流的方式是链路。那么当到达接口B的限流上限,接口A就无法访问,但是接口C还可以继续访问不受影响。

graph TD 接口A --> 接口B 接口C --> 接口B
接口B

定义资源使用@SentinelResource

java 复制代码
@Service
public class UserService {

    @SentinelResource("userName")
    public String getUserName(){
        return "sentinel";
    }
}
调用接口B
java 复制代码
@ApiOperation("s1")
@GetMapping("/s1")
public String s1(HttpServletRequest request){
    System.out.println("s1");
    String user = userService.getUserName();
    return "hello s1 "+user+" ...9001";
}
调用接口A
less 复制代码
@ApiOperation("s2")
@GetMapping("/s2")
public String s2(HttpServletRequest request){
    System.out.println("s2");
    String user = userService.getUserName();
    return "hello s2"+user+" ...9001";
}
增加配置

新增:web-context-unify: false

yaml 复制代码
server:
  port: 9001

spring:
  application:
    name: user
  cloud:
    discovery:
      server-addr: 127.0.0.1:8848
    sentinel:
      transport:
        dashboard: localhost:8080
        port: 8720
      web-context-unify: false
management:
  endpoint:
    web:
      exposure:
        include:'*'

swagger:
  enabled: true
sentinel注册信息
验证

被拒绝的请求如下:

流控效果:Warm Up

Warm Up使用场景:预热/冷启动方式。该方式主要用于系统长期处于低水位的情况下,当流量突然增加时,直接把系统拉升到高水位可能瞬间把系统压垮。通过"冷启动",让通过的流量缓慢增加,在一定时间内逐渐增加到阈值上限,给冷系统一个预热的时间,避免冷系统被压垮的情况。

相关推荐
掘根4 小时前
【微服务即时通讯】文件存储子服务
微服务·云原生·架构
喵叔哟8 小时前
19-AIAgent智能代理开发
微服务·.net
麦聪聊数据10 小时前
SQL 到 API 转化过程中的版本控制与灰度发布机制
数据库·sql·低代码·微服务
喵叔哟11 小时前
20-多模态AI应用开发
人工智能·微服务·.net
fajianchen12 小时前
如何设计微服务统一认证中心
微服务·云原生·架构·iam
愿^O^~13 小时前
VSCode 启动 Spring Boot 微服务 JMX 端口冲突问题
spring boot·vscode·微服务
洛邙13 小时前
互联网大厂Java求职面试实录:Spring Boot与微服务实战解析
java·spring boot·缓存·微服务·面试·分布式事务·电商
一叶飘零_sweeeet13 小时前
从单体地狱到微服务天堂:架构演进与拆分的核心原则+全链路实战落地
微服务·架构
闫小甲13 小时前
Spring Cloud Gateway vs Apache APISIX:统一网关与鉴权方案深度对比
微服务·架构·apisix·ssg