sentinel踩坑记录——持续更新ing

发布时间 2023-11-26 13:57:37作者: Littstone

Bug1

自定义被限流的后续操作@SentinelResource(blockHandler = "blockHandler"),其中blockHandler处理函数不执行

前置条件

  
  //定义的资源
  @GetMapping("/resource") @SentinelResource(value = "/resource", blockHandler = "blockHandler") public String resource(int a){ return "resourcce" + a; } public String blockHandler(int a, BlockException e) { return "被限流了..." + a + e.getMessage(); }

 定义好资源和流控规则之后,如果每秒访问超过2个请求,那么就会触发流控,从而应该执行 blockHandler(int a, BlockException e) 方法,但是实际情况是即使触发了流控规则依然提示的是

 并没有触发blockHandler方法,后来我又去仔细看了一下文档,显示如下,发现返回值、访问范围、参数要求都一致,但就是不执行该方法。

 我又去翻看了一下文档发现了一个案例,如下

 我对照了一下我的代码发现,与这个案例的不同只有资源的定义名称了,我的资源定义的是“/resource”,难不成是因为多了一个“/”的原因?

发现问题之后把资源名称改成了“resource”,再重启服务,定义流控规则,再尝试一遍发现成功了,能执行blockHandler方法了。最后附上代码

 @GetMapping("/resource")
    @SentinelResource(value = "resource", blockHandler = "blockHandler")
    public String resource(int a){
        return "resourcce" + a;
    }

    public String blockHandler(int a, BlockException e) {
        return "被限流了..." + a + e.getMessage();
    }