spring-retry简单使用方法
在分布式系统中,为了保证数据分布式事务的强一致性,大家在调用RPC接口或者发送MQ时,针对可能会出现网络抖动请求超时情况采取一下重试操作。大家用的最多的重试方式就是MQ了,但是如果你的项目中没有引入MQ,那就不方便了,本文主要介绍一下如何使用SpringRetry实现重试操作。
1.添加maven依赖
org.springframework.retry spring-retry 1.1.2.RELEASE org.aspectj aspectjweaver 1.5.4
2.在启动里添加重试配置
@SpringBootApplication @EnableRetry publicclassApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(Application.class,args); } }
3.编写Service
@Service publicclassRemoteService{ privatestaticfinalLoggerlogger=LoggerFactory.getLogger(TestController.class); @Retryable(value={BusinessException.class},maxAttempts=3,backoff=@Backoff(delay=5000l,multiplier=2)) publicvoidcall()throwsException{ logger.info("dosomething..."); thrownewBusinessException("RPC调用异常"); } @Recover publicvoidrecover(BusinessExceptione){ logger.info("---------------------------"); logger.info(e.getMessage()); } }
4.编写Controller
@RestController @RequestMapping("/test") publicclassTestController{ privatestaticfinalLoggerlogger=LoggerFactory.getLogger(TestController.class); @Autowired privateRemoteServiceremoteService; @RequestMapping("/test") publicStringlogin()throwsException{ remoteService.call(); returnString.valueOf("11"); }
5.访问http://localhost:8080/test/test
6.测试日志
2017-07-2519:28:07[INFO]-[http-nio-53602-exec-1]-[com.test.retry.service.RemoteService.call(RemoteService.java:19)]dosomething...
2017-07-2519:28:12[INFO]-[http-nio-53602-exec-1]-[com.test.retry.service.RemoteService.call(RemoteService.java:19)]dosomething...
2017-07-2519:28:22[INFO]-[http-nio-53602-exec-1]-[com.test.retry.service.RemoteService.call(RemoteService.java:19)]dosomething...
2017-07-2519:28:22[INFO]-[http-nio-53602-exec-1]-[com.test.retry.service.RemoteService.recover(RemoteService.java:24)] ---------------------------
2017-07-2519:28:22[INFO]-[http-nio-53602-exec-1]-[com.test.retry.service.RemoteService.recover(RemoteService.java:25)]RPC调用异常
7.相关配置说明
@EnableRetry能否重试。当proxyTargetClass属性为true时,使用CGLIB代理。默认使用标准JAVA注解。在springBoot中此参数写在程序入口即可。
@Retryable标注此注解的方法在发生异常时会进行重试
value:指定处理的异常类
include:指定处理的异常类和value一样,默认为空,当exclude也为空时,默认所有异常
exclude:指定异常不处理,默认空,当include也为空时,默认所有异常
maxAttempts:最大重试次数。默认3次
backoff:重试等待策略。默认使用@Backoff注解
@Backoff重试等待策略
不设置参数时,默认使用FixedBackOffPolicy(指定等待时间),重试等待1000ms
设置delay,使用FixedBackOffPolicy(指定等待时间),重试等待填写的时间
设置delay和maxDealy时,重试等待在这两个值之间均态分布
设置delay、maxDealy、multiplier,使用ExponentialBackOffPolicy(指数级重试间隔的实现),multiplier即指定延迟倍数,比如delay=5000l,multiplier=2,则第一次重试为5秒,第二次为10秒,第三次为20秒……
@Recover用于@Retryable重试失败后处理方法,此注解注释的方法参数一定要是@Retryable抛出的异常,否则无法识别,可以在该方法中进行日志处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。