Spring 块、平面图和订阅之间的 webflux 区别
Spring webflux difference between block, flatmap and subscribe
我有一个 api 需要调用其他 3 个 api,第二个和第三个 api 调用依赖于第一个的结果。
我对执行此操作的最佳方法以及使用块、订阅和平面图之间的区别有些困惑。这 3 种方法都对我有用,但我不确定哪一种是最好的。
这是我目前拥有的:
webClient1.getApi1(request.getId())
.subscribe(api1Response -> {
if (api1Response.hasData()) {
Mono<ApiTwoResponse> monoTwo = webClient2
.post()
.syncBody(...)
.bodyToMono(ApiTwoResponse.class)
monoTwo.subscribe(two -> log.info(two));
Mono<ApiThreeResponse> monoThree = webClient3
.put()
.syncBody(...)
.bodyToMono(ApiThreeResponse.class)
monoThree.subscribe(three -> log.info(three));
}
});
我也尝试过阻止,尽管这似乎是不鼓励的:
Api1Response response = webClient1.getApi1(request.getId()).block()
我也试过 flatmap 虽然这迫使你 return 一些东西:
webClient1.getApi1(request.getId())
.flatmap(api1Response -> {
...
return Mono.empty();
});
感谢对上述代码的任何帮助和反馈。
block
操作,本质上是停止等待。它将等同于 java 中的 Future.get()。它违背了非阻塞代码的目的。
Flatmap
将一个序列的序列展平为一个序列,因此一个列表 {List{?}} 将变成一个列表{Object}。
subscribe
基本上开始倾听,并且可以执行操作。通常在订阅之前什么都不会发生。
但对于您的用例,您可以使用 filter
这是一个示例,
它会过滤 {true, false} 项目,然后对于每个为真的过滤器,
我将两个单声道的结果压缩在一起,然后订阅一个动作
Flux<Boolean> bool = Flux.just(true, false);
Mono<Integer> mono1 = Mono.just(1);
Mono<String> mono2 = Mono.just("string");
bool.filter(b -> b)
.flatMap(b -> Mono.zip(mono1, mono2))
.subscribe(tuple -> System.out.println(tuple.getT1() + ", " + tuple.getT2()));
我有一个 api 需要调用其他 3 个 api,第二个和第三个 api 调用依赖于第一个的结果。
我对执行此操作的最佳方法以及使用块、订阅和平面图之间的区别有些困惑。这 3 种方法都对我有用,但我不确定哪一种是最好的。
这是我目前拥有的:
webClient1.getApi1(request.getId())
.subscribe(api1Response -> {
if (api1Response.hasData()) {
Mono<ApiTwoResponse> monoTwo = webClient2
.post()
.syncBody(...)
.bodyToMono(ApiTwoResponse.class)
monoTwo.subscribe(two -> log.info(two));
Mono<ApiThreeResponse> monoThree = webClient3
.put()
.syncBody(...)
.bodyToMono(ApiThreeResponse.class)
monoThree.subscribe(three -> log.info(three));
}
});
我也尝试过阻止,尽管这似乎是不鼓励的:
Api1Response response = webClient1.getApi1(request.getId()).block()
我也试过 flatmap 虽然这迫使你 return 一些东西:
webClient1.getApi1(request.getId())
.flatmap(api1Response -> {
...
return Mono.empty();
});
感谢对上述代码的任何帮助和反馈。
block
操作,本质上是停止等待。它将等同于 java 中的 Future.get()。它违背了非阻塞代码的目的。
Flatmap
将一个序列的序列展平为一个序列,因此一个列表 {List{?}} 将变成一个列表{Object}。
subscribe
基本上开始倾听,并且可以执行操作。通常在订阅之前什么都不会发生。
但对于您的用例,您可以使用 filter
这是一个示例,
它会过滤 {true, false} 项目,然后对于每个为真的过滤器,
我将两个单声道的结果压缩在一起,然后订阅一个动作
Flux<Boolean> bool = Flux.just(true, false);
Mono<Integer> mono1 = Mono.just(1);
Mono<String> mono2 = Mono.just("string");
bool.filter(b -> b)
.flatMap(b -> Mono.zip(mono1, mono2))
.subscribe(tuple -> System.out.println(tuple.getT1() + ", " + tuple.getT2()));