2

目前我正在探索实现“在 Spring Boot 中以 AOP 方式进行请求超时管理”的方法,但有几个限制。要求/限制如下:

  • 本来的目的是如果一个api请求的处理时间超过5秒,那么直接返回超时结果,而不是继续处理
  • 要监控的rest api由标准的spring mvc rest控制器实现。里面的所有api都返回这样的json字符串:

    @RestController
    public class xxxxxx {
        @RequestMapping(value = "xxxxxxx")
        public String xxxxxx(@RequestParam(value = "xxxx", required = true) String xxxx) {
            ....
            return json.toString();
        }
    }
    
  • 超时逻辑需要AOP实现
  • (真正的意思部分) 不应该对控制器进行任何更改,这意味着:不应该更改请求生成方法;返回类型不应更改(不允许'Callable<...>')

我已经找到了 1 个答案(异步方法),它可以通过 spring async 完美地解决问题本身,并且超时返回结果非常漂亮,但是它改变了返回类型,并且还触及了控制器中的代码。我还找到了一种使用 AOP 的解决方案(AOP 方法),但场景与我的完全不同。它已经将一些业务逻辑移动到 AOP 类中,但不允许我接触控制器代码。如果有人能提供解决方案,我将不胜感激。不能满足所有限制但最小化差异的解决方案也被接受。

4

1 回答 1

2

由于这个问题还没有得到回复,所以我将自己的临时解决方案放在这里。

我正在使用 Hystrix 依赖项。

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-hystrix</artifactId>
        <version>1.4.0.RELEASE</version>
    </dependency>

它与springboot很好地集成在一起,所以配置很简单。正确配置后,需要在需要超时处理的请求方法上附加注释。例如

@HystrixCommand(fallbackMethod="fallback")
@RequestMapping(value = "xxxxxxx")
public String xxxxxx(@RequestParam(value = "xxxx", required = true) String xxxx) {
    ....
    return json.toString();
}

并且需要添加一个后备方法,其名称映射到注释内的“fallbackMethod”的值:

public String fallback() {
   ...
}

超时时间值可以在 application.properties 中全局配置

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=3000
hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds=3000

这在以下几点上仍然不够简洁:

  • 需要为每个方法复制/粘贴此注释
  • 需要在每个使用 hystrix 的地方复制/粘贴回退方法
  • 对于 hystrix fallback 方法本身,参数类型和数量需要与 hystrix 标记方法完全相同。目前,我在每个控制器中为此使用了几种称为“回退”的重载方法

但至少它不再更改方法返回类型和方法内部的代码,并且是我目前能想到的最佳解决方案。一旦我找到更好的解决方案,将执行更新。

于 2017-12-01T04:18:52.647 回答