У меня есть метод, который перебирает товары из корзины и размещает заказ на них, используя placeOrder.
После того, как placeOrder вызван для всех товаров в корзине, я хочу объединить и отправить один моно-объект, в котором указывается, какой заказ прошел, а какой нет
Этот код работает, но не использует параллельное выполнение placeOrder.
List<Mono<OrderResponse>> orderResponse = new ArrayList<Mono<OrderResponse>>();
OrderCombinedResponse combinedResponse = new OrderCombinedResponse();
//placeIndividualOrder returns Mono<OrderResponse>
session.getCartItems().forEach(cartItem ->
orderResponse.add(placeIndividualOrder(cartItem)));
return Flux.concat(orderResponse).collectList().map(responseList -> {
responseList.forEach(response -> {
//Do transformation to separate out failed and successful order
});
//Return Mono<OrderCombinedResponse> object
return combinedResponse;
});
Я пытаюсь использовать приведенный ниже код для параллельной обработки заказов в корзине, но он не возвращает никакого ответа и просто выходит
//Return Mono<OrderCombinedResponse> object
return Flux.fromIterable(session.getCartItems()).parallel()
//Call method to place order. This method return Mono<OrderResponse>
.map(cartItem -> placeIndividualOrder(cartItem))
.runOn(Schedulers.elastic())
//
.map(r -> {
r.subscribe(response -> {
//Do transformation to separate out failed and successful order
});
return combinedResponse;
});