博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springboot 整合retry(重试机制)
阅读量:5040 次
发布时间:2019-06-12

本文共 2023 字,大约阅读时间需要 6 分钟。

当我们调用一个接口可能由于网络等原因造成第一次失败,再去尝试就成功了,这就是重试机制,spring支持重试机制,并且在Spring Cloud中可以与Hystaix结合使用,可以避免访问到已经不正常的实例。

写一个简单的demo,加入依赖:

org.springframework.boot
spring-boot-starter-web
org.springframework.retry
spring-retry
org.aspectj
aspectjweaver

在主类上加上@EnableRetry注解,表示启用重试机制。

@SpringBootApplication@EnableRetrypublic class Application { public static void main(String[] args) { SpringApplication.run(Application.class,args); } }

定义一个简单的controller层:

@RestControllerpublic class HelloController { Logger logger = LoggerFactory.getLogger(getClass()); @Autowired private PayService payService; @GetMapping("/createOrder") public String createOrder(@RequestParam int num) throws Exception{ int remainingnum = payService.minGoodsnum(num == 0 ? 1: num); logger.info("剩余的数量==="+remainingnum); return "库库存成功"; } }

在controller中调用减库存的service接口,

@Servicepublic class PayService { private Logger logger = LoggerFactory.getLogger(getClass()); private final int totalNum = 100000; @Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5)) public int minGoodsnum(int num) throws Exception{ logger.info("minGoodsnum开始"+ LocalTime.now()); if(num <= 0){ throw new Exception("数量不对"); } logger.info("minGoodsnum执行结束"); return totalNum - num; } }

在minGoodsnum方法上加上@Retryable注解,value值表示当哪些异常的时候触发重试,maxAttempts表示最大重试次数默认为3,delay表示重试的延迟时间,multiplier表示上一次延时时间是这一次的倍数。

测试:

 
图片.png
 
图片.png

重试三次抛出异常。

使用@Recover注解,当重试次数达到设置的次数的时候,还是失败抛出异常,执行的回调函数。

关于@Recover注解

 
图片.png

和minGoodsnum定义在一个类中

@Recoverpublic int recover(Exception e){ logger.warn("减库存失败!!!"); //记日志到数据库 return totalNum; }

重试测试一下,

 
图片.png

感觉意义不大,重试失败的时候应该还是要抛出异常的,在上层进行catch记录日志,当然也有特殊的场景适用。

作者:二月_春风
链接:https://www.jianshu.com/p/314059943f1c
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

转载于:https://www.cnblogs.com/lywJ/p/10730904.html

你可能感兴趣的文章
[51nod1267]4个数和为0(预处理+双指针)
查看>>
[poj2151]Check the difficulty of problems概率dp
查看>>
深入浅出之Smarty模板引擎工作机制(一)
查看>>
Java动态代理机制
查看>>
linux mail 命令参数
查看>>
android 网络语音电话合集 此文为转载备份
查看>>
hdu 5071 vector操作恶心模拟
查看>>
ECShop 常见问题索引
查看>>
0916 编程实验一 词法分析程序
查看>>
angular和echarts的结合使用,折线图指令
查看>>
洛谷 P1227 [JSOI2008]完美的对称
查看>>
2019牛客暑期多校训练营(第二场)
查看>>
Intellij新建Spring项目引入用户目录下的Spring jar包
查看>>
iOS 动画基础-显式动画
查看>>
surprise库官方文档分析(二):使用预测算法
查看>>
正规文法转化DFA
查看>>
敏捷开发(三)- 估算故事
查看>>
bzoj 2730: [HNOI2012]矿场搭建
查看>>
Asp.net MVC 中Ajax的使用 [分享]
查看>>
重新配置dbconsole的步骤
查看>>