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;
}
可以了