如何解决成功和错误时记录响应时间 - Webflux即使出现错误也会调用 doOnSuccess
我编写了这个过滤器来测量 API 的响应时间。当我收到错误时触发 onSuccess 。 有没有办法分别登录成功和错误以更好地记录。
public class RequestTimingFilter implements WebFilter {
@Override
public Mono<Void> filter(ServerWebExchange exchange,WebFilterChain chain) {
if (exchange.getRequest().getPath().value().contains("something")) {
long startMillis = System.currentTimeMillis();
return chain
.filter(exchange)
.doOnSuccess(
success ->
log.info(
"Api call successfull: {}ms",System.currentTimeMillis() - startMillis));
}
return chain.filter(exchange);
}
}
解决方法
我能够通过使用以下代码来实现这一点 -
return chain
.filter(exchange)
.then(
Mono.fromRunnable(
() -> {
ServerHttpResponse response = exchange.getResponse();
if (Objects.requireNonNull(response.getStatusCode()).is2xxSuccessful()) {
log.info(
"Success: {}ms",System.currentTimeMillis() - startMillis);
} else {
log.info("Failure");
}
}));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。