半亩花草 发表于 2024-1-12 08:20:39

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

Bug1

自定义被限流的后续操作@SentinelResource(blockHandler = "blockHandler"),其中blockHandler处理函数不执行
前置条件
  <br>  //定义的资源<br>  @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();
    }https://img2023.cnblogs.com/blog/2677429/202311/2677429-20231126133820669-1586824386.png
 定义好资源和流控规则之后,如果每秒访问超过2个请求,那么就会触发流控,从而应该执行 blockHandler(int a, BlockException e) 方法,但是实际情况是即使触发了流控规则依然提示的是
https://img2023.cnblogs.com/blog/2677429/202311/2677429-20231126134338601-2119369443.png
 并没有触发blockHandler方法,后来我又去仔细看了一下文档,显示如下,发现返回值、访问范围、参数要求都一致,但就是不执行该方法。
https://img2023.cnblogs.com/blog/2677429/202311/2677429-20231126134131113-304473190.png
 我又去翻看了一下文档发现了一个案例,如下
https://img2023.cnblogs.com/blog/2677429/202311/2677429-20231126134612896-2008698730.png
 我对照了一下我的代码发现,与这个案例的不同只有资源的定义名称了,我的资源定义的是“/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();
    } 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: sentinel踩坑记录——持续更新ing