首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Resilience4j在尝试过的方法中返回CompletableFuture

Resilience4j在尝试过的方法中返回CompletableFuture
EN

Stack Overflow用户
提问于 2020-05-29 10:46:13
回答 1查看 1.5K关注 0票数 1

我无法了解如何用Resilience4j包装同步方法,以便它返回一个CompletableFuture,尽管这似乎是Resilience4j的目标区域的一部分。特别是因为我想包装的同步方法可能引发异常。我想要的伪代码:

代码语言:javascript
复制
boolean void syncMethod() throws Exception {
    // May throw Exception due to connection/authorization problems.
}

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

Resilience4j应该尝试调用该方法4次,直到它放弃为止,每次调用间隔为100 ms,然后完成异步调用。asyncResilience4jWrapper调用者应该只返回一个不阻塞的CompletableFuture,而不关心这些。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-29 12:35:01

代码语言:javascript
复制
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(3);
TimeLimiter timeLimiter = TimeLimiter.of(Duration.ofSeconds(1));

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

只需将withRetry添加到CircuitBreaker下面即可。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62084143

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档