gpt4 book ai didi

java - Resilience4j 返回一个带有参数的尝试过的方法的 CompletableFuture

转载 作者:行者123 更新时间:2023-12-01 16:25:58 24 4
gpt4 key购买 nike

我不知道如何使用 Resilience4j 包装同步方法,以便它返回 CompletableFuture,尽管这似乎是 Resilience4j 的目标区域的一部分。特别是因为我想要包装的同步方法可能会抛出异常。我想要的伪代码:

boolean void syncMethod(Parameter param) throws Exception {
// May throw Exception due to connection/authorization problems.
}

CompletableFuture<Boolean> asyncResilience4jWrapper() {
CompletableFuture<Boolean> result =
...
Resilience4j magic around "syncMethod(param)".
Trying 4 calls, interval between calls of 100 ms.
...;
return result;
}

Resilience4j 应该尝试调用该方法 4 次,直到放弃,调用之间的间隔为 100 毫秒,然后完成异步调用。asyncResilience4jWrapper 调用者应该只返回一个 CompletableFuture,它不会阻塞并且不关心任何这些。

真正困难的部分似乎是让它运行带有参数的方法,并抛出异常!

最佳答案

就这么做

CompletableFuture<Boolean> asyncResilience4jWrapper(Parameter param) {
return CompletableFuture<Boolean> future = Decorators.ofCallable(() -> syncMethod(param))
.withThreadPoolBulkhead(threadPoolBulkhead)
.withTimeLimiter(timeLimiter, scheduledExecutorService)
.withCircuitBreaker(circuitBreaker)
.withRetry(retry)
.withFallback(asList(TimeoutException.class, CallNotPermittedException.class, BulkheadFullException.class),
throwable -> "Hello from Recovery")
.get().toCompletableFuture();
}

关于java - Resilience4j 返回一个带有参数的尝试过的方法的 CompletableFuture,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62147297/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com