如何计算总执行时间并在响应标头中设置,即Spring WebFlux中每个请求的x运行时



我不知道我的方法是否正确?另外,如果还有其他解决方法可以实现这一目标,请告诉我。

可以使用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);
    }
}

如果你使用的是Spring Boot,你应该使用spring-boot-starter-actuator

如果你没有使用Spring Boot,你仍然应该看看Micrometer,它可以检测Spring WebFlux来收集这类数据。

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

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

无论如何,你可以看看Spring Boot的MetricsWebFilter(这里(,看看千分尺是如何实现的。

最新更新