Mono.fromCompletionStage重试不工作

private static Mono<String> generate(String res) {
    return generateMono(res)
            .retryWhen(Retry.max(4)
                    .filter(e -> e instanceof Exception)
                    .doAfterRetry(retryRes -> System.out.println("try finished" + retryRes.totalRetries() + "次")))
            .onErrorResume(Mono::error);
}
private static Mono<String> generateMono(String res) {
    CompletableFuture<String> stringCompletableFuture = CompletableFuture.supplyAsync(() -> {
        System.out.println("dee");
        if (retryTime.get() == 2) {
            return "stringCompletableFuture";
        }
        System.out.println("i am called" + retryTime.getAndAdd(1));
        throw new IllegalArgumentException("exception test");
//            return res;
    });

    return Mono.fromCompletionStage( stringCompletableFuture);

}

结果:没有重试,cf中的逻辑只被调用了一次。
在这里插入图片描述
google之后发现别人也遇到类似问题:https://artofcode.wordpress.com/2022/07/05/project-reactors-mono-completablefuture-and-retrying/

于是改成这样:

private static Mono<String> generateMono(String res) {
    CompletableFuture<String> stringCompletableFuture = CompletableFuture.supplyAsync(() -> {
        System.out.println("dee");
        if (retryTime.get() == 2) {
            return "stringCompletableFuture";
        }
        System.out.println("i am called" + retryTime.getAndAdd(1));
        throw new IllegalArgumentException("exception test");
//            return res;
    });

    return Mono.fromCompletionStage( ()->stringCompletableFuture);
}

结果:依旧不行
最后单独抽出来一个方法:

private static Mono<String> generateMono(String res) {
    return Mono.fromCompletionStage( ()->getFuture());
}
private static CompletableFuture<String>getFuture() {
    CompletableFuture<String> stringCompletableFuture = CompletableFuture.supplyAsync(() -> {
        System.out.println("dee");
        if (retryTime.get() == 2) {
            return "stringCompletableFuture";
        }
        System.out.println("i am called" + retryTime.getAndAdd(1));
        throw new IllegalArgumentException("exception test");
//            return res;
    });
    return stringCompletableFuture;

}

可以了
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值