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

相关推荐
蝎子莱莱爱打怪6 天前
XZLL-IM干货系列 04|Netty 长连接实战:Pipeline 怎么排、心跳怎么跳、连接怎么管
后端·微服务·面试
SamDeepThinking7 天前
Java微服务练习方式
java·后端·微服务
米丘10 天前
微前端之 Web Components 完全指南
微服务·html
霸道流氓气质13 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
霸道流氓气质13 天前
Spring Boot 微服务性能优化完全指南
spring boot·微服务·性能优化
地瓜伯伯13 天前
从MESI缓存一致性协议讲透synchronized的底层
java·spring boot·spring·spring cloud·微服务·springcloud
Devin~Y13 天前
大厂 Java 面试实录:从音视频内容社区到 AI RAG 的全链路技术设计
java·spring boot·redis·spring cloud·微服务·kafka·音视频
递归尽头是星辰13 天前
AI 访问数据仓库:从直连到微服务化
数据仓库·人工智能·微服务·dataagent·ai数据治理
就改了14 天前
Windows 环境 SkyWalking 完整实操教程
windows·微服务·skywalking
至乐活着14 天前
Docker Compose多服务编排实战:从零搭建Node.js+MySQL+Redis全栈应用
docker·微服务·devops·容器编排·compose