其他分享
首页 > 其他分享> > SpringBoot集成Sentinel 限流 熔断 系统保护

SpringBoot集成Sentinel 限流 熔断 系统保护

作者:互联网

前言:

Sentinel是针对高并发架构的一个很有效果的中间件,对于限流、熔断、策略访问、消峰、冷启动、系统保护等常见极端场景有很好的防护作用,下面为其使用过程。

配置与依赖:

(注意:从GitHub上直接粘贴的依赖可能不起作用,原因是无version)

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
    <version>2.2.0.RELEASE</version>
</dependency>

然后在resources文件夹下新建一名为“application.yml”的文件,内容如下:

server:
  port: 80
  servlet:
      context-path: "/"

限流示例:

@RestController
public class CurrentLimitController {

    @RequestMapping(value = "/limit", method = RequestMethod.GET)
    public String findController() {
        try(Entry entry = SphU.entry("TEST_LIMIT")){
            return "REQUEST OK.";
        } catch (Exception e){
            e.printStackTrace();
            return "ERROR.";
        }

    }

    @PostConstruct
    public void initFlowRules(){
        List<FlowRule> flowRuleList = new ArrayList<>();
        FlowRule flowRule = new FlowRule();
        flowRule.setResource("TEST_LIMIT");
        flowRule.setGrade(RuleConstant.FLOW_GRADE_QPS);
        flowRule.setCount(2);
        flowRuleList.add(flowRule);
        FlowRuleManager.loadRules(flowRuleList);
    }

}

必要说明:

注解使用:

注解使用配置有一点点繁琐,但是代码很简单。
添加注解所需依赖:

<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-annotation-aspectj</artifactId>
    <version>1.8.0</version>
</dependency>

新建config文件夹,在其下新建名为SentinelAspectConfiguration的配置类文件,内容如下:

@Configuration
public class SentinelAspectConfiguration {

    @Bean
    public SentinelResourceAspect sentinelResourceAspect(){
        return new SentinelResourceAspect();
    }

}

下面就是Controller层内容。

@RestController
public class CurrentLimitController {

    @PostConstruct
    public void initFlowRules(){
        List<FlowRule> flowRuleList = new ArrayList<>();
        FlowRule flowRule = new FlowRule();
        flowRule.setResource("TEST_2");
        flowRule.setGrade(RuleConstant.FLOW_GRADE_QPS);
        flowRule.setCount(2);
        flowRuleList.add(flowRule);
        FlowRuleManager.loadRules(flowRuleList);
    }

    @SentinelResource(value = "TEST_2", blockHandler = "blockHandler")
    @RequestMapping(value = "/limit2", method = RequestMethod.GET)
    public String findController2() {
        return "NORMAL BUSINESS.";
    }

    public String blockHandler(BlockException e){
        e.printStackTrace();
        return "BAD REQUEST.";
    }

}

说明:
blockHandler为降级处理者,对应有一个名称相同的方法,专门用来处理降级所需的业务逻辑。

熔断 系统保护请看下篇文章。

标签:return,SpringBoot,FlowRule,public,TEST,限流,Sentinel,flowRuleList,flowRule
来源: https://blog.csdn.net/kicinio/article/details/120103079