《Sentinel 服务限流、降级》

《Sentinel 服务限流、降级》

一、准备服务消费者(端口8080)

1、添加依赖。

<!-- 引入 Sentinel 依赖 -->

        <dependency>

            <groupId>com.alibaba.csp</groupId>

            <artifactId>sentinel-core</artifactId>

            <version>1.7.2</version>

        </dependency>

        

2、bootstrap.properties 配置 Nacos

server.port=8081

 

spring.application.name=service-consumer

 

# nacos 作为注册中心

spring.cloud.nacos.discovery.server-addr=192.168.1.x:8848

 

3、设置资源限流规则

@Component

@RestController

@RequestMapping("sentinelTest")

public class SentinelTestController {

 

    @PostConstruct

    private void postC() {

        initFlowRules(); // 临时初始化sentinel配置

    }

 

    /**

     * helloWorld() 方法就成了我们的一个资源。注意注解支持模块需要配合 Spring AOP 或者 AspectJ 一起使用。

     */

//    @SentinelResource("HelloWorld")

//    @RequestMapping("/helloWorld")

//    public String helloWorld() {

//        // 资源中的逻辑

//        System.out.println("hello world");

//        return "hello world";

//    }

 

    @SentinelResource("HelloWorld")

    @RequestMapping("/helloWorld")

    public String helloWorld() {

 

        // 1.5.0 版本开始可以直接利用 try-with-resources 特性,自动 exit entry

        try (Entry entry = SphU.entry("HelloWorld")) {

            // 被保护的逻辑

            System.out.println("hello world");

            return "hello world";

        } catch (BlockException ex) {

            // 处理被流控的逻辑

            System.out.println("blocked!");

        }

 

        return "blocked";

    }

 

    /**

     * 使用代码设置sentinel,也可以在sentinel-Dashboard控制台设置

     */

    // @RequestMapping("/initFlowRules")

    private void initFlowRules() {

        List<FlowRule> rules = new ArrayList<>();

        FlowRule rule = new FlowRule();

        rule.setResource("HelloWorld");

        rule.setGrade(RuleConstant.FLOW_GRADE_QPS);

        // Set limit QPS to 20.

//        rule.setCount(20);

        rule.setCount(1);

        rules.add(rule);

        FlowRuleManager.loadRules(rules);

    }

}

 

测试:

http://xx/sentinelTest/helloWorld

每秒正常服务1个请求,超出的请求被拒绝了

### Sentinel 限流与熔断降级工作原理 #### 一、Sentinel 工作机制概述 Sentinel 是一款专注于流量控制和服务高可用性的开源组件,能够帮助开发者保护应用免受过载影响。通过配置不同的规则集来实现对请求量的限制(即限流),并对可能出现的服务不稳定情况进行处理(即熔断)。这有助于提高系统的稳定性和响应速度。 #### 二、限流策略详解 对于限流而言,Sentinel 提供了多种方式让用户可以根据实际需求灵活设置: - **QPS (Queries Per Second)**:基于每秒查询次数来进行限制; - **并发线程数**:设定允许的最大并行执行任务数量; - **调用关系**:针对特定路径或方法实施更细粒度的访问频率管理; 一旦触发预设条件,新来的请求将会被拒绝,并返回相应的错误提示给客户端[^1]。 ```java // 配置 QPS 类型的限流规则示例 FlowRule rule = new FlowRule(); rule.setResource("exampleApi"); rule.setGrade(RuleConstant.FLOW_GRADE_QPS); rule.setCount(20); // 设置最大允许的 qps 数值为 20 ``` #### 三、熔断降级逻辑解析 关于熔断降级方面,在一段时间内如果某个服务连续出现了过多失败情况,则认为该服务暂时不可靠而自动将其隔离掉。具体来说就是当资源在过去一分钟内的异常数目超过了指定阈值之后就会启动熔断机制。需要注意的是因为统计数据的时间窗口是以分钟计算所以即使设置了较短的 `timeWindow` 参数也有可能再次进入熔断状态直到下一个完整的周期到来[^2]。 在此期间任何对该服务的新请求都将直接得到一个默认回复而不是真正去尝试连接它从而避免不必要的等待时间和潜在风险。与此同时还可以配合自定义 slot 来增强这一过程中的监控能力以便及时发现和解决问题所在[^3]。 #### 四、网关模式下特殊说明 值得注意的是,在采用 Spring Cloud Gateway 结合 Alibaba Cloud Sentinel 构建的应用程序中,所有的路由都会映射到对应的 sentinel 资源上。这意味着在网关模式里所创建的所有限流及熔断规则都应当依据具体的 API 路径而非内部微服务之间的依赖关系进行定义。此外,由于架构特性所致,此类场景下的链路级别限流措施并不适用[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值