贝利信息

如何在 Quarkus 或 Mutiny 中实现异步操作的顺序执行与容错处理

日期:2026-01-02 00:00 / 作者:花韻仙語

本文介绍如何使用 mutiny 的 `multi` 和 `uni` 实现对列表元素的逐个异步调用,确保严格串行执行、失败不中断,并优雅降级。

在响应式编程中,「顺序执行多个异步任务」是一个常见但易被误解的需求。不同于并行(transformToUniAndMerge)或无序(transformToUniAndConcatenate 的非严格串行变体),真正的逐项等待前一项完成后再发起下一项,需依赖 Mutiny 的 transformToUniAndConcatenate —— 它会将每个 Uni 串联(concatenate)执行,即前一个 Uni 终止(无论成功或失败)后,才订阅下一个。

以下为完整实现方案:

import io.smallrye.mutiny.Multi;
import io.smallrye.mutiny.Uni;

// 假设已有:
// List elements;
// private Uni asyncMethod(Element element) { ... }

Multi sequentialResults = Multi.createFrom()
    .iterable(elements)
    .onItem()
    .transformToUniAndConcatenate(element -> 
        asyncMethod(element)
            .onFailure() // 捕获任意异常(包括 checked exception 包装后的 RuntimeException)
            .recoverWithItem("fallback_for_" + element.getId()) // 自定义降级值(类型须匹配 String)
            // 或使用 continueWith(() -> Uni.createFrom().item(...)) 实现更复杂逻辑
    );

关键点说明:

⚠️ 注意事项:

通过上述方式,你既能保持响应式链的声明式表达力,又精准满足「顺序、容错、持续」三大约束。