kms*_*333 4 spring project-reactor spring-webflux
我有一个简单的Java程序,它使用Spring WebClient发送多个请求.每个都返回一个单声道,我使用response.subscribe()来检查结果.
但是,我的主要执行线程在处理所有请求之前完成,除非我添加一个长的Thread.sleep().
使用CompletableFutures,您可以使用:CompletableFuture.allOf(期货).join();
有没有办法等待所有Mono完成?
正如Project Reactor文档中所解释的那样,直到你subscribe进入a Publisher.该操作返回一个实例Disposable,这意味着该操作可能仍在进行.
如果您不在非阻塞的反应管道中(例如,HTTP请求/响应交换或批处理操作),并且您需要在退出VM之前等待该管道的完成 - 那么您可以block().这实际上是为数不多的"允许"用例之一.
您的问题并没有真正解释"检查回复"的含义.在这里,我们将获得POJO(如果HTTP响应状态不是200或者如果我们不能反序列化响应,则将发送错误信号).在您的示例中,您可以使用以下内容:
Mono<User> one = this.webClient...
Mono<Account> two = this.webClient...
Mono<Book> three = this.webClient...
// we want all requests to happen concurrently
Mono<Void> all = Mono.when(one, two, three);
// we subscribe and then wait for all to be done
all.block();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5032 次 |
| 最近记录: |