目前我正在探索在Spring Boot中以AOP方式实现'请求超时管理'的方法,但存在一些限制。要求/限制如下:
要监控的其余API由标准弹簧mvc休息控制器实现。里面的所有apis都返回json字符串,如下所示:
@RestController
public class xxxxxx {
@RequestMapping(value = "xxxxxxx")
public String xxxxxx(@RequestParam(value = "xxxx", required = true) String xxxx) {
....
return json.toString();
}
}
我已经找到了1个答案(Async approach),可以通过spring async完美地解决问题本身,并且超时返回结果非常漂亮,但是它正在改变返回类型,并且还触及控制器中的代码。我还找到了一个使用AOP的解决方案(AOP approach),但场景与我的完全不同。它已经将一些业务逻辑转移到AOP类中,但我不允许触摸控制器代码。如果有人能提供解决方案,我将不胜感激。我们也承认无法满足所有限制但最大限度地减少差异的解决方案。
答案 0 :(得分:1)
由于对此问题仍无回应,我将在此处提出自己的临时解决方案。
我正在使用Hystrix依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
<version>1.4.0.RELEASE</version>
</dependency>
它与springboot很好地集成,因此配置很简单。正确配置后,需要在需要超时处理的请求方法上附加注释。 e.g。
@HystrixCommand(fallbackMethod="fallback")
@RequestMapping(value = "xxxxxxx")
public String xxxxxx(@RequestParam(value = "xxxx", required = true) String xxxx) {
....
return json.toString();
}
并且需要添加一个后备方法,其名称映射到&#39; fallbackMethod&#39;的值。内部注释:
public String fallback() {
...
}
可以在application.properties
中全局配置超时时间值hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000
hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds=3000
在这些方面仍然不够简洁:
但至少它不再改变方法中的方法返回类型和代码,这是我目前能想到的最佳解决方案。一旦找到更好的解决方案,就会执行更新。