阿丹:
记录一次开发中遇到的错误。
报错信息描述:
2023-10-01 09:47:57.263 ERROR 39572 --- [nio-9100-exec-2] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is java.lang.reflect.UndeclaredThrowableException] with root cause
com.alibaba.csp.sentinel.slots.block.flow.FlowException: null
问题出现场景:
因为我是开发后端嘛,使用Sentinel的注解来给我的接口做了一下限流,限流的效果是正常的,但是发现我的回调函数并不能正常被触发。
问题出现原因:
根据错误信息来看,这是一个com.alibaba.csp.sentinel.slots.block.flow.FlowException
异常。该异常通常由流控规则引起,表示请求被阻塞或限流了。
要解决这个问题,你可以考虑以下几个方面:
-
检查流控规则:检查Sentinel的流控规则是否正确配置并能够满足你的需求。确保规则没有过于严格的限制导致请求被拒绝。
-
检查资源使用情况:查看应用程序的资源使用情况,特别是在流控发生时。如果资源使用过高,可以考虑优化代码或增加资源容量来避免流控。
-
检查Sentinel配置:确保Sentinel的相关配置正确无误。例如,检查Sentinel的配置文件是否正确加载,规则是否生效等。
解决方式:
1、回调函数的参数要与被限流的参数保持一致,并且接口的后面添加一个参数。
2、要保证限流的回调函数的返回值与被限流的接口保持一致
正确的代码
java
@SentinelResource(value = "findByUsername" ,blockHandler = "blockHandlerForGetUser")
@GetMapping("/findByUsername/{username}")
public User findByUsername(@PathVariable String username){
return service.findByUsername(username);
}
public User blockHandlerForGetUser(@PathVariable String username, BlockException blockException){
User user = new User();
user.setUsername("限流统一返回类");
return user;
}