如何计算总执行时间并在Spring WebFlux中为每个请求设置响应头,即x-runtime?

时间:2018-01-26 09:54:23

标签: spring spring-webflux

我不知道我的方法是否正确?另外,如果有任何其他解决办法,请告诉我。

是否可以使用WebFilter?

package request.middlewares;

import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import org.springframework.web.server.WebFilter;
import org.springframework.web.server.WebFilterChain;
import reactor.core.publisher.Mono;

@Component
public class ResponseTimeCalculator implements WebFilter {

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain) {
        // is it possible here?
        exchange.getResponse().getHeaders().add("X-Runtime", "10ms");
        return chain.filter(exchange);
    }
}

1 个答案:

答案 0 :(得分:0)

如果您使用的是Spring Boot,则应使用spring-boot-starter-actuator

如果你没有使用Spring Boot,你仍然应该看一下Micrometer,它会使Spring WebFlux收集这类数据。

请注意,您的方法存在许多缺陷:

  • 处理程序链可能会返回,但实际的响应处理/写入可能尚未完成
  • 使用简单的计时器不会考虑GC暂停
  • 看测量样本并不重要,百分位数会给你更多

在任何情况下,您都可以查看Spring Boot的MetricsWebFilterhere),了解Micrometer的实现方式。