我正在使用反应式编程,其中客户端接收服务器端事件的事件流,然后消耗这些事件。在功能上明智地起作用。当我尝试记录流量流中的总记录数时出现问题。下面是代码段。
我们创建一个连接到服务器的实例
final WebClient client = WebClient
.builder()
.baseUrl(url)
.build();
然后我们开始连接,并订阅其主题
final Flux<ServerSentEvent<SomeEvent>> eventStream = client.get()
.uri("/bus/sse?id=" + subscription)
.accept(MediaType.TEXT_EVENT_STREAM)
.exchange()
.flatMapMany(response -> response.bodyToFlux(type))
.repeat();
log(eventStream, "connectSSE");
eventStream
.doOnError(throwable -> this.onError(throwable, eventStream))
.doOnComplete(() -> this.onComplete(eventStream));
subscribe = eventStream.subscribe(someServerSideEvent -> this.onEvent(someServerSideEvent , eventStream));
下面的方法处理事件
private void onEvent(final ServerSentEvent<SomeEvent> content, Flux<ServerSentEvent<SomeEvent>> eventStream) {
log(eventStream, "onEvent");
//Code for handling event
}
以下代码段有问题。实际上,我想记录流中的记录数,我期望它会打印一些数字,但它会打印如下内容。需要一些解决方案而不使用.block()。欢迎任何帮助。
“此Flux中的计数值:MonoMapFuseable,调用方onEvent”
private void log1(Flux<ServerSentEvent<SomeEvent>> eventStream, final String caller) {
try {
eventStream.count().map(count -> {
LOGGER.info("Counted values in this Flux: {}, caller {}", count.longValue(), caller);
return count;
});
} catch (final Exception e) {
LOGGER.info("Counted values in this Flux failed", e);
}
}