ToB企服应用市场:ToB评测及商务社交产业平台
标题:
sentinel踩坑记录——持续更新ing
[打印本页]
作者:
半亩花草
时间:
2024-1-12 08:20
标题:
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();
}
复制代码
定义好资源和流控规则之后,如果每秒访问超过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();
}
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4