第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何等待訂閱完成?

如何等待訂閱完成?

倚天杖 2022-12-28 15:38:30
我想進行一個異步休息調(diào)用,我正在使用 spring webclient 并取回 Mono。我也在并行進行一些數(shù)據(jù)庫調(diào)用,但由于某種原因無法被動完成。    Map<String, Object> models = new HashMap<>();    Mono<User> users = this.webClient...;    users.map(resp -> new UserState(userRequest, resp))            .subscribe(response -> {                models.put("userState", response);            });    Iterable<Product> messages = this.productRepository.findAll();    models.put("products", messages);    //Wait for users.subscribe to finish <<<<<<<<<<<<<HERE    return new ModelAndView("messages/list", models);如何在返回 ModelAndView 之前等待訂閱完成。Future如果我使用一個我可以get()隨時隨地做的地方,這會很容易。
查看完整描述

1 回答

?
搖曳的薔薇

TA貢獻1793條經(jīng)驗 獲得超6個贊

您可以將阻塞調(diào)用包裝在Mono一個單獨的調(diào)度程序上執(zhí)行,將其與Mono包含的UserState數(shù)據(jù)一起壓縮并將它們的組合轉(zhuǎn)換為一個Mono<ModelAndView>(可以從 Spring 控制器方法返回)。調(diào)用將并行執(zhí)行,兩個調(diào)用完成后將合并結(jié)果。


您可以為每個應用程序定義一個專門用于阻塞調(diào)用的有界調(diào)度程序,并將其作為構(gòu)造函數(shù)參數(shù)提供給任何進行阻塞調(diào)用的類。


代碼如下所示:


@Configuration 

class SchedulersConfig {


  @Bean

  Scheduler parallelScheduler(@Value("${blocking-thread-pool-size}") int threadsCount) {

    return Schedulers.parallel(threadsCount);

  }

}


@RestController

class Controller {


  final Scheduler parallelScheduler;


  ...


  Mono<User> userResponse = // webClient...


  Mono<Iterable<Product>> productsResponse = Mono.fromSupplier(productRepository::findAll)

    .subscribeOn(parallelScheduler); 


  return Mono.zip(userResponse, productsResponse, (user, products) -> 

    new ModelAndView("messages/list", 

      ImmutableMap.of(

        "userState", new UserState(userRequest, user),

        "products", products

      ))

  );

}

根據(jù)評論更新:

如果您只需要異步執(zhí)行 HTTP 調(diào)用,然后將其與數(shù)據(jù)庫結(jié)果結(jié)合起來,您可以執(zhí)行以下操作


Map<String, Object> models = new HashMap<>();

Mono<User> userMono = webClient...;

CompletableFuture<User> userFuture = userMono.toFuture();

Iterable<Product> messages = productRepository.findAll();

User user = userFuture.join();

models.put("products", messages);

models.put("userState", new UserState(userRequest, user));

return new ModelAndView("messages/list", models);


查看完整回答
反對 回復 2022-12-28
  • 1 回答
  • 0 關(guān)注
  • 100 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號