如何获取服务器端事件Flux中的记录总数

时间:2020-05-29 11:58:01

标签: mono flux

我正在使用反应式编程,其中客户端接收服务器端事件的事件流,然后消耗这些事件。在功能上明智地起作用。当我尝试记录流量流中的总记录数时出现问题。下面是代码段。

我们创建一个连接到服务器的实例

        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);
    }
}

0 个答案:

没有答案