Springboot 整合Retry 实现重试机制
重试,在项目需求中是非常常见的,例如遇到网络波动等,要求某个接口或者是方法可以最多/最少调用几次;
实现重试机制,非得用Retry这个重试框架吗?那肯定不是,相信很多伙伴手写一下控制流程的逻辑也可以达到重试的目的。
那么用Retry的好处是什么? 简单来说,就是优雅。
Retry重试框架,支持AOP切入的方式使用,而且能使用注解;想想,重试次数、重试延迟、重试触发条件、重试的回调方法等等我们都能很轻松结合注解以一种类似配置参数的方式去实现,优雅无疑。
那么,我们接下来就来一起使用Springboot整合这个Retry重试框架:
首先是pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.6.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.mail</groupId><artifactId>elegant</artifactId><version>0.0.1-SNAPSHOT</version><name>elegant</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry</artifactId></dependency><dependency><groupId>org.aspectj</groupId ><artifactId>aspectjweaver</artifactId ><version>1.6.11</version ></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
然后创建一个测试重试的TestRetryService.java:
/*** @Author : JCccc* @CreateTime : 2019/8/16* @Description :**/
public interface TestRetryService {int dignifiedTest(int code) throws Exception;
}
然后是TestRetryServiceImpl.java:
import com.mail.elegant.service.TestRetryService;
import org.springframework.retry.annotation.Backoff;
import org.springframework.retry.annotation.Recover;
import org.springframework.retry.annotation.Retryable;
import org.springframework.stereotype.Service;
import java.time.LocalTime;/*** @Author : JCccc* @CreateTime : 2019/8/16* @Description :**/
@Service
public class TestRetryServiceImpl implements TestRetryService {@Override@Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5))public int dignifiedTest(int code) throws Exception{System.out.println("dignifiedTest被调用,时间:"+LocalTime.now());if (code==0){throw new Exception("情况不对头!");}System.out.println("dignifiedTest被调用,情况对头了!");return 200;}@Recoverpublic int recover(Exception e){System.out.println("回调方法执行!!!!");//记日志到数据库 或者调用其余的方法return 400;}}
到这里,已经整合完毕,最后剩下测试了,在测试前,我们先一起来看看代码里面的关键信息的意义:
可以看到代码里面,这个方法上面加上了注解 ,
@Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5,maxDelay=360000L))
@Retryable : 注解方式标记当前方法会使用重试机制
里面的 value: 重试的触发机制,当遇到Exception异常的时候,触发;
maxAttempts: 重试的次数(包括第一次调用,也就是说如果设置3次,调用一次后,如果一直失败触发重试,那么还当前方法还会调用2次);
delay:重试的延迟时间,也就是距离上一次重试方法调用的间隔,单位毫秒
multiplier: delay间隔时间的倍数,也就是说,第一次重试间隔如果是2000ms,那第二次重试的时候就是2000ms 乘以这个倍数1.5,就是3000ms;
maxDelay:重试次数之间的最大时间间隔,默认为0,即忽略,如果小于delay的设置,则默认为30000L;
再来看下面的这个小方法:
@Recover
public int recover(Exception e){System.out.println("回调方法执行!!!!");//记日志到数据库 或者调用其余的方法return 400;
}
这个方法用到了@Recover,也就是用注解方式标记当期方法为回调方法,可以看到传参里面写的是 Exception e,这个是作为回调的接头暗号(重试次数用完了,还是失败,我们抛出这个Exception e通知触发这个回调方法)。
PS:该回调方法与重试方法写在同一个实现类里面。
然后在启动类加上开启重试注解:
@EnableRetry
好了,基本简单讲解完毕,接下来测试看看什么效果,
创建一个TestController.java ,写过简单的测试方法:
import com.mail.elegant.service.TestRetryService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;/*** @Author : JCccc* @CreateTime : 2019/8/16* @Description :**/
@RestController
public class TestController {@AutowiredTestRetryService testRetryServiceImpl;@GetMapping("/testRetry")public String testRetry() throws Exception {int code=0;int result = testRetryServiceImpl.dignifiedTest(code);return "result:"+result;}}
我们这个测试模拟的场景是,传值code,一直是0;然后业务方法判断如果是0,代表业务不通,失败(网络波动了或者是等等),然后就是触发重试,最后如果重试几次都不成功,然后调用回调方法(可以进行日志记录或者调用其他业务方法等等)。
我们调用接口看看效果:
接口返回了400,是回调方法返回的:
看看控制台输出情况:
OK,到此,重试整合及测试已经完毕。
(ps:如果不需要回调方法,可以直接不写回调方法,那么实现的效果是,重试次数完了后,如果还是没成功没符合业务判断,就抛出异常)
Springboot 整合Retry 实现重试机制相关推荐
- springboot 整合retry(重试机制)
当我们调用一个接口可能由于网络等原因造成第一次失败,再去尝试就成功了,这就是重试机制,spring支持重试机制,并且在Spring Cloud中可以与Hystaix结合使用,可以避免访问到已经不正常的 ...
- kafka 安装使用 /springboot整合kafka /消息投递机制以及存储策略 /副本处理机制
一.背景 1.基本信息 Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写.Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流 ...
- Netty(一) SpringBoot 整合长连接心跳机制
https://github.com/crossoverJie/JCSprout 原创: crossoverJie 阅读原文 前言 Netty 是一个高性能的 NIO 网络框架,本文基于 Spring ...
- 基于springboot整合spring-retry
1.背景 本系统调用外围系统接口(http+json),但是发现有时外围系统服务不太稳定,有时候会出现返回一串xml或者gateway bad的信息,导致调用失败,基于这一原因,采用基于springb ...
- Springboot(SpringBoot)重试机制retry
在我们编写项目时,有时候需要调用外部接口,那这个时候就需要考虑如果出现异常怎么办,可能是网络访问异常,超时异常等等.SpringBoot为我们提供了重试机制,可适用于这种场景, 一.retry重试机制 ...
- Spring Retry 重试机制实现及原理
概要 Spring实现了一套重试机制,功能简单实用.Spring Retry是从Spring Batch独立出来的一个功能,已经广泛应用于Spring Batch,Spring Integration ...
- Spring异常重试机制 - Spring Retry
目录 一 . 引入依赖 二 . 在启用类或业务类上添加@EnableRetry注解启用重试机制(在启用类上添加全局有效 , 在业务类上添加仅当前有效) 三 . 使用@Retryable实现重试 四 . ...
- Springboot:商品库存并发更新,乐观锁失败重试机制
一个商城项目,用户下单时需要更新商品库存,在商品类增加了version字段,增加乐观锁,保证库存数据的线程安全,但是在多个用户同时下单更新库存时可能会导致库存更新失败,因此需要增加乐观锁失败重试机制 ...
- python redis 哨兵_Redis高可用哨兵机制及SpringBoot整合哨兵
前言:在前面讲到了Redis分片机制可实现内存数据的扩容来提高执行速率---Redis分片机制,可是Redis分片依旧有一些问题,如果redis分片的节点如果有一个服务器宕机,则直接影响用户的使用.R ...
最新文章
- 在Ubuntu 16.04.04 LTS上调研QUIC开源项目minq笔记
- 如何使用 Python 或 Bash动态生成 Jekyll 配置文件
- 可视化卷积神经网络的过滤器_万字长文:深度卷积神经网络特征可视化技术(CAM)最新综述...
- vue 强制刷新组件
- L1-003 个位数统计
- ubuntu 18.04 安装 opencv3.4.1 以及 opencv_contrib 3.4.1] 亲测可用
- 7、调用存储过程和函数
- 温州大学计算机网络,数据通信与计算机网络(温州大学)实验四 - 运输层TCP和UDP协议分析.doc...
- [转]JSP中EL表达式三元运算符的使用
- 3d vision可以卸载吗_金属粉末可以用于3D打印,但这些知识你了解吗?
- Cocos2d开发1:Xcode与TexturePacker的集成
- 一分钟!不写代码!给网站添加【统计分析】
- TCP/IP 第三章
- 【重学计算机】计组D1章:计算机系统概论
- linux efi分区安装grub2,GitHub - beatfan/UEFI_grub2: uefi 版本 grub2,可以引导多系统,以及linux的安装...
- Xenserver 为XenCenter添加本地磁盘
- 《高质量C++/C编程指南(林锐)》学习笔记
- 数据结构课程设计c语言-校园导游系统
- 基于社交网络的推荐算法
- 又拍云php表单,又拍云php版Token授权防盗链整理 - YangJunwei
热门文章
- [野火]一种Cortex-M内核中的精确延时方法-ns级别-DWT
- iphone html5音乐播放器,从界面到功能 五款iPhone音乐播放器年度横评
- 001 变量与数据类型
- MT4电脑版下载和安装
- 非科班学python就业_非科班出身自学Python,这些实用方法学习方法你知道吗!
- 数据库优化有哪些? 分别需要注意什么
- Hero In Maze 简单版
- 【Mo 人工智能技术博客】python玩转信号处理与机器学习入门
- online boosting 和 batch boosting的区别
- CFD软件开发漫谈-1: 整体规划