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

相关推荐
一只蒟蒻ovo9 分钟前
操作系统导论——第26章 并发:介绍
java·开发语言
老华带你飞18 分钟前
音乐网站|基于SprinBoot+vue的音乐网站(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·音乐网站
熊文豪31 分钟前
Java+Selenium+快代理实现高效爬虫
java·爬虫·selenium·隧道代理·快代理
purrrew1 小时前
【Java ee 初阶】多线程(8)
java·java-ee
TPBoreas4 小时前
Jenkins 改完端口号启动不起来了
java·开发语言
金斗潼关4 小时前
SpringCloud GateWay网关
java·spring cloud·gateway
TE-茶叶蛋5 小时前
Vuerouter 的底层实现原理
开发语言·javascript·ecmascript
云闲不收5 小时前
设计模式原则
开发语言
秋名RG5 小时前
深入解析建造者模式(Builder Pattern)——以Java实现复杂对象构建的艺术
java·开发语言·建造者模式
eternal__day6 小时前
Spring Boot 实现验证码生成与校验:从零开始构建安全登录系统
java·spring boot·后端·安全·java-ee·学习方法