SpringBoot集成接口重试Retry

SpringBoot集成接口重试Retry

前言

在实际的应用中,我们经常需要调用第三方API来获取数据或执行某些操作。然而,由于网络不稳定、第三方服务异常等原因,API调用可能会失败。为了提高系统的稳定性和可靠性,我们通常会考虑实现重试机制。

集成

1、引入pom坐标

java 复制代码
		<dependency>
            <groupId>org.springframework.retry</groupId>
            <artifactId>spring-retry</artifactId>
        </dependency>

同时需要aop的依赖包:

java 复制代码
	<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

启动类加注解:

java 复制代码
@EnableRetry

2、代码示例

2.1配置重试策略
java 复制代码
	@Override
    @Retryable(value = {RestClientException.class},maxAttempts = 3,backoff = @Backoff(delay = 1000,multiplier = 2))
    public String callThirdPartyApi() {

        //调用第三方API接口逻辑

        return null;
    }

@Retryable注解标记了callThirdPartyApi方法,指定了当发生RestClientException异常时进行重试。

maxAttempts指定最大重试次数。

backoff指定了重试间隔的初始延迟和延迟倍数。

2.2降级处理
java 复制代码
	@Override
    @Retryable(value = {RestClientException.class},maxAttempts = 3,backoff = @Backoff(delay = 1000,multiplier = 2))
    public String callThirdPartyApi() {

        //调用第三方API接口逻辑

        return null;
    }

    @Recover
    public String fallback(){
        
        //降级处理逻辑
        
        return null;
    }

@Recover注解标记了fallback方法,当callThirdPartyApi方法的重试次数达到上限时,将执行fallback方法中的降级逻辑。

2.3异步方法的重试及降级
java 复制代码
	@Async
  	@Retryable(value = {RestClientException.class},maxAttempts = 3,backoff = @Backoff(delay = 1000,multiplier = 2))
    public CompletableFuture<String> callAsyncThirdPartyApi() {
        //调用第三方API接口逻辑
    }

    @Recover
    public CompletableFuture<String> fallback() {
        // 异步降级处理逻辑
    }
2.4异常分类与重试
java 复制代码
@Retryable(
        value = { RestClientException.class, TimeoutException.class },
        maxAttempts = 3,
        backoff = @Backoff(delay = 1000, multiplier = 2)
    )
    public String callThirdPartyApi() {
        // 调用第三方API的逻辑
        // ...
    }

callThirdPartyApi方法会在发生RestClientExceptionTimeoutException异常时进行重试。

java 复制代码
@Retryable(
        value = { RestClientException.class },
        maxAttempts = 3,
        backoff = @Backoff(delay = 1000, multiplier = 2),
        exclude = { TimeoutException.class }
    )
    public String callThirdPartyApi() {
        // 调用第三方API的逻辑
        // ...
    }

callThirdPartyApi方法会在发生RestClientException异常时进行重试,但排除了TimeoutException异常。

相关推荐
玉宇夕落几秒前
别再死磕 Prompt 了!上下文工程 (Context Engineering) 的简单学习
后端
用户342323237631722 分钟前
定时器与 PWM 输出详解
后端
Jason_chen1 小时前
Linux 6.2 CAN/CANFD机制详解
后端
plainGeekDev2 小时前
GreenDAO → Room
android·java·kotlin
Apifox2 小时前
Apifox 6 月更新|Apifox CLI 全面升级、导入导出优化、OAuth 2.0 支持自动刷新令牌
前端·后端·测试
悟空瞎说2 小时前
NestJS 接口设计避坑:摒弃万能用户更新接口,落地单一职责与最小权限原则
后端·nestjs
smallyoung2 小时前
Spring AI 2.0 VectorStore实战:从原理到RAG落地
人工智能·后端
jiayou642 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
青丘2 小时前
Spring AI整合Milvus向量数据库实战
后端