我不知道我的方法是否正确?另外,如果还有其他解决方法可以实现这一目标,请告诉我。
可以使用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
(这里(,看看千分尺是如何实现的。