摘要
重试机制在网络服务中非常的重要,由于网路可能存在延迟,网络抖动,网络不稳定的情况。同时在分布式服务中网络的请求的高度密集,有些服务不一定能在规定的时间内完成访问。应该请求服务需要重试几次。以保证服务请求成功。在spring中也有相关的重试依赖。
一、spring的retry依赖
<!--重试-->
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
二、spring重试机制的实战
@SpringBootApplication
@EnableRetry
public class AdminApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(AdminApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(AdminApplication.class);
}
}
- 给需要重试的方法添加重试注解@Retryable
- value值表示当哪些异常的时候触发重试
- maxAttempts 最大重试次数 三次
- delay表示重试的延迟时间
- multiplier表示上一次延时时间是这一次的倍数
@Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5))
public void testRetry() throws Exception {
System.out.println("==========开始执行========="+new Date().getTime());
if (1==1) {
String str = "wobenshanliang";
// 产生异常异常
Integer integer = Integer.valueOf(str);
}
System.out.println("=======执行成功=======");
}
当重试次数达到设置的最大次数的时候,还是失败抛出异常,执行的回调函数。
回调函数需要和重试方法在一个类中。
@Recover
public void testRecover(Exception e){
System.out.println("=======重试次数到达最大值,重试结束===="+e.getMessage());
}
执行的结果
===============开始执行===================1606274378617
===============开始执行===================1606274380618
===============开始执行===================1606274383618
=============重试次数到达最大值,重试结束=========For input string: "wobenshanliang"
三、重试机制原理
在引入spring-retry依赖中通过@EnableRetry开启重试机制,同时在方法上标注的@Retryable,其底层实现原理还是AOP的切向编程思想,通过生成代理对象,里实现对方法的重试机制。