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

相关推荐
麦聪聊数据7 小时前
利用SQL2API模式重构微服务中的数据查询层
数据库·sql·低代码·微服务·架构
九皇叔叔9 小时前
【03】微服务系列 之Nacos 注册中心(服务注册)
java·微服务·nacos·架构·注册中心·服务注册
what丶k11 小时前
微服务稳定性守护者:Sentinel 全面使用指南(从入门到企业级落地)
微服务·架构·sentinel
九皇叔叔12 小时前
【04】微服务系列 之 Nacos 注册中心(服务发现)
java·微服务·nacos·服务发现
猿小羽12 小时前
领域驱动设计(DDD)在电商系统中的架构落地指南(含中英术语对照与图表)
微服务·架构·ddd·领域驱动设计
小信丶12 小时前
@Activate 注解详解:应用场景与实战示例
java·spring boot·后端·spring·spring cloud·微服务·dubbo
未来之窗软件服务13 小时前
商业应用(3)建材城商铺租赁管理系统—东方仙盟练气期
大数据·微服务·架构·商业应用·仙盟创梦ide·东方仙盟
编程彩机13 小时前
互联网大厂Java面试:从Spring MVC到微服务架构场景解析
java·spring cloud·微服务·分布式事务·spring mvc
夜月蓝汐14 小时前
若依微服务版集成阿里云oss
java·阿里云·微服务
编程彩机14 小时前
互联网大厂Java面试:从Spring Boot到微服务的技术场景解读
spring boot·微服务·消息队列·java面试·分布式系统