ToB企服应用市场:ToB评测及商务社交产业平台

标题: sentinel踩坑记录——持续更新ing [打印本页]

作者: 半亩花草    时间: 2024-1-12 08:20
标题: sentinel踩坑记录——持续更新ing
Bug1

自定义被限流的后续操作@SentinelResource(blockHandler = "blockHandler"),其中blockHandler处理函数不执行
前置条件
  1.   <br>  //定义的资源<br>  @GetMapping("/resource")
  2.     @SentinelResource(value = "/resource", blockHandler = "blockHandler")
  3.     public String resource(int a){
  4.         return "resourcce" + a;
  5.     }
  6.     public String blockHandler(int a, BlockException e) {
  7.         return "被限流了..." + a + e.getMessage();
  8.     }
复制代码

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

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

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

 我对照了一下我的代码发现,与这个案例的不同只有资源的定义名称了,我的资源定义的是“/resource”,难不成是因为多了一个“/”的原因?
发现问题之后把资源名称改成了“resource”,再重启服务,定义流控规则,再尝试一遍发现成功了,能执行blockHandler方法了。最后附上代码
  1. @GetMapping("/resource")
  2.     @SentinelResource(value = "resource", blockHandler = "blockHandler")
  3.     public String resource(int a){
  4.         return "resourcce" + a;
  5.     }
  6.     public String blockHandler(int a, BlockException e) {
  7.         return "被限流了..." + a + e.getMessage();
  8.     }
复制代码
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4