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 项目

相关推荐
TT哇7 小时前
【实习】数字营销系统 银行经理端(interact_bank)前端 Vue 移动端页面的 UI 重构与优化
java·前端·vue.js·ui
Elieal7 小时前
SpringBoot 数据层开发与企业信息管理系统实战
java·spring boot·后端
识君啊7 小时前
MyBatis-Plus 逻辑删除导致唯一索引冲突的解决方案
java·spring boot·mybatis·mybatis-plus·唯一索引·逻辑删除
Coder_Boy_7 小时前
Java开发者破局指南:跳出内卷,借AI赋能,搭建系统化知识体系
java·开发语言·人工智能·spring boot·后端·spring
QT.qtqtqtqtqt7 小时前
SQL注入漏洞
java·服务器·sql·安全
独自破碎E7 小时前
BISHI23 小红书推荐系统
java·后端·struts
Mr_Xuhhh7 小时前
介绍一下ref
开发语言·c++·算法
xqqxqxxq7 小时前
Java IO 核心:BufferedReader/BufferedWriter & PrintStream/PrintWriter 技术笔记
java·笔记·php
Aric_Jones8 小时前
idea使用.env运行SpringBoot项目
java·spring boot·intellij-idea
nbsaas-boot8 小时前
软件开发最核心的理念:接口化与组件化
开发语言