前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >项目实战:第三方接口调用,超时失败时的重试方案

项目实战:第三方接口调用,超时失败时的重试方案

作者头像
MavenTalker
发布2023-03-10 20:46:33
1.4K0
发布2023-03-10 20:46:33
举报
文章被收录于专栏:歪脖贰点零歪脖贰点零

在实际工作过程中,重试是一个经常使用的手段。比如工程中使用http请求外部服务,可能因为网络异常出现超时而采取重试手段,查阅了N多资料,也未发现有成型的框架可以支持失败重试策略,幸运的是还是有成型的中间件中关注过此问题的。

从Spring Batch 2.2.0开始,重试功能作为一个新的项目Spring Retry单独维护,在spring官网上并没有此独立的项目存在,项目源码地址:https://github.com/spring-projects/spring-retry,资料比较少,想深入的同学只能读取e文了。

实际应用案例:

1、maven项目的pom中引入依赖

代码语言:javascript
复制
 <!-- https://mvnrepository.com/artifact/org.springframework.retry/spring-retry -->
 <dependency>
     <groupId>org.springframework.retry</groupId>
     <artifactId>spring-retry</artifactId>
     <version>1.1.2.RELEASE</version>
 </dependency>

2、编写测试类,图中示例为X征信第三方查询接口

抛出RuntimeException异常后,继续重试,最多重试5次,每次在上一次的基础上延后1秒,multiplier为乘系数。若5次重试后依旧失败,则默认调用带有注解@Recover的方法,给接口返回一个默认值。

运行结果如下

以上示例是最简单的用法,可以git clone源码深入了解下,相信失败发试的场景很多,特别是依赖第三方服务的场景。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2016-09-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MavenTalk 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档