Sentinel

目录

一、Sentinel 简介

Sentinel 是阿里巴巴开源的分布式系统流量防卫组件,提供流量控制熔断降级系统自适应保护等功能。作为 Spring Cloud Alibaba 核心组件,广泛应用于电商秒杀、直播等高并发场景,防止系统因突发流量崩溃。

核心特性

  • 流量控制:基于 QPS/并发数/调用关系多维度限流
  • 熔断降级:自动检测慢调用/异常比例触发熔断
  • 热点防护:针对高频参数自动限流
  • 系统保护:根据系统负载动态调整流量
  • 实时监控:秒级监控数据可视化

二、环境准备

1. 控制台安装

bash 复制代码
# 下载最新版本(以 1.8.5 为例)
wget https://github.com/alibaba/Sentinel/releases/download/1.8.5/sentinel-dashboard-1.8.5.jar

# 启动控制台(默认端口 8080)
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -jar sentinel-dashboard-1.8.5.jar

访问 http://localhost:8080(默认账号密码:sentinel/sentinel)

2. Spring Boot 集成

xml 复制代码
<!-- pom.xml -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
    <version>2022.0.0.0</version>
</dependency>
yaml 复制代码
# application.yml
spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8080
      eager: true # 立即注册到控制台

三、核心功能实战

1. 流量控制

定义资源

java 复制代码
@GetMapping("/order")
@SentinelResource(value = "createOrder", blockHandler = "handleFlowLimit")
public String createOrder() {
    return "订单创建成功";
}

// 流控处理函数
public String handleFlowLimit(BlockException ex) {
    return "系统繁忙,请稍后再试!";
}

控制台配置

  1. 在控制台找到对应资源
  2. 新增流控规则:QPS=2(阈值类型选QPS,单机阈值=2)
  3. 使用 JMeter 压测验证效果

2. 熔断降级

java 复制代码
@SentinelResource(value = "paymentService", 
                  fallback = "paymentFallback",
                  exceptionsToIgnore = {IllegalArgumentException.class})
public String processPayment(String orderId) {
    // 业务逻辑
}

// 降级处理函数
public String paymentFallback(String orderId, Throwable t) {
    return "支付服务暂时不可用,请稍后重试";
}

熔断规则配置

  • 熔断策略:慢调用比例
  • 最大 RT:500ms
  • 比例阈值:0.5(50%)
  • 熔断时长:5秒
  • 最小请求数:5

3. 热点参数限流

java 复制代码
@GetMapping("/product")
@SentinelResource(value = "queryProduct", blockHandler = "paramFlowHandler")
public String getProduct(@RequestParam("pid") String productId) {
    return "商品详情";
}

// 热点参数处理
public String paramFlowHandler(String productId, BlockException ex) {
    return "当前商品访问火爆,请稍后再试";
}

参数规则配置

java 复制代码
ParamFlowRule rule = new ParamFlowRule("queryProduct")
    .setParamIdx(0) // 参数索引
    .setCount(10);  // 阈值
ParamFlowRuleManager.loadRules(Collections.singletonList(rule));

四、高级配置

1. 规则持久化(Nacos 集成)

xml 复制代码
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-datasource-nacos</artifactId>
</dependency>
yaml 复制代码
spring:
  cloud:
    sentinel:
      datasource:
        ds1:
          nacos:
            server-addr: localhost:8848
            dataId: sentinel-rules
            groupId: DEFAULT_GROUP
            rule-type: flow

2. 集群流控

java 复制代码
// 启动 Token Server
ClusterServerConfigManager.loadServerNamespaceSet(Collections.singleton("App-Cluster"));
yaml 复制代码
# token-server 配置
spring:
  cloud:
    sentinel:
      transport:
        client-ip: 192.168.1.10
        cluster-server:
          port: 18730

五、生产实践建议

  1. 压测基准 :通过 curl http://localhost:8719/tree?type=root 获取资源树
  2. 监控集成:对接 Prometheus + Grafana
  3. 动态调整:使用 Sentinel 的 HTTP API 实时修改规则
  4. 异常处理 :统一实现 BlockExceptionHandler 接口

完整示例代码:Sentinel Demo 项目

相关推荐
软件开发技术局43 分钟前
撕碎QT面具(8):对控件采用自动增加函数(转到槽)的方式,发现函数不能被调用的解决方案
开发语言·qt
周杰伦fans2 小时前
C#中修饰符
开发语言·c#
yngsqq2 小时前
c# —— StringBuilder 类
java·开发语言
赔罪3 小时前
Python 高级特性-切片
开发语言·python
星星点点洲3 小时前
【操作幂等和数据一致性】保障业务在MySQL和COS对象存储的一致
java·mysql
xiaolingting3 小时前
JVM层面的JAVA类和实例(Klass-OOP)
java·jvm·oop·klass·instanceklass·class对象
风口上的猪20153 小时前
thingboard告警信息格式美化
java·服务器·前端
子豪-中国机器人4 小时前
2月17日c语言框架
c语言·开发语言
夏天的阳光吖4 小时前
C++蓝桥杯基础篇(四)
开发语言·c++·蓝桥杯
追光少年33224 小时前
迭代器模式
java·迭代器模式