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异常。

相关推荐
uzong38 分钟前
一次慢接口背后,竟藏着40+种可能!你中过几个
后端·面试·程序员
G探险者1 小时前
滴滴P0级故障背后:互联网公司是如何分级处理线上事故的?
后端
G探险者2 小时前
从 Tomcat 与 Jetty 的对比,聊聊影响一个服务并发能力的关键因素
后端
你的人类朋友2 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
南尘NCA86662 小时前
企业微信防封防投诉拦截系统:从痛点解决到技术实现
java·网络·企业微信
幼稚园的山代王2 小时前
go语言了解
开发语言·后端·golang
kkjt01302 小时前
{MySQL查询性能优化索引失效的八大场景与深度解决方案}
后端
怪兽20143 小时前
SQL优化手段有哪些
java·数据库·面试
ss2733 小时前
手写MyBatis第107弹:@MapperScan原理与SqlSessionTemplate线程安全机制
java·开发语言·后端·mybatis
橙子家3 小时前
log4net 简介以及简单示例(.net8)
后端