Цели:
- Запускать блокирующие и длительные задачи после доставки ответа Webflux (сбрасывается в выходной поток)
- Последующие вызовы блокировки не должны вызывать каких-либо проблем для внутреннего Spring/Reactor/Netty-Event-Loop пулы потоков
- возможный лучший способ запустить задачу блокировки после доставки ответа
Кроме того, может ли виртуальный пул потоков быть полезен для выполнения задач блокировки? если да, то как?
@RestController
public class RestEndpoint {
@PostMapping(path = "process", produces = MediaType.TEXT_PLAIN_VALUE)
public Mono service(@RequestBody String request) {
String txnId = UUID.randomUUID().toString();
return Mono.just(txnId ).doOnResponseSent(() -> {
//Blocking & Long Running(10-50 seconds) calls here
blockingDatabaseCallToStoreResponse(txnId);
blockingRestClientCallToSomebodyElse(txnId);
blockingDatabaseCallToStoreSomethingElse();
});
}
}
Подробнее здесь: https://stackoverflow.com/questions/798 ... -delivered
Мобильная версия