springboot +aop使用guavaretryer 的重试机制

简介: 1. 最近在公司在进行rpc 调用的时候,对方的服务不太稳定. 需求就是要间隔多长时间,多少次来重试。达到最大值之后就不在重试。
  1. 最近在公司在进行rpc 调用的时候,对方的服务不太稳定. 需求就是要间隔多长时间,多少次来重试。达到最大值之后就不在重试。
  2. 看了好多的资料,发现了一个开源的guavaretryer, 比较简单对用户非常的友好。
  3. 我们先新建一个springboot的项目,要引入guava-retry 的包,它会自动引入guava的包。


我们将其打开,看一下Retryer这个类


这里面是它的一些参数,具体的意思看注释就行了。
我们主要看一下call 方法


这里也就是表明返回的是两种值,一个是你自己自定义callable 返回 的值,一个是Throwable 的值。
下面还有一个监听器。


在下面就是在尝试,可以尝试就返回结果。不能尝试就走下面的是否应该停止,要是可以停止的话,就抛出retry 异常,
不可以的话就阻塞,就是组织结束尝试,要是保错的话,会对当前进程进行中断。

4,下面我们写一个自定义的注解加上aop 来 实现这个功能,
先写一个自定义注解

在写一个aop


这里retryer使用的是构建者模式,第一个的意思是如果返回值是null, 我们上面的cell()满足。 如果报错了返回值是null , 下面是异常类型,在注解里面声明了。在下面是否是运行是的异常。 下面就是重试的时间间隔和单位, 下面就是多少次之后就停止重试。

5 我们在写一个接口测试一下


先测试一下正常情况


没问题, 在测试一下异常情况,把刚才的注释放开
看一下控制台和浏览器


就是我们注解默认的重试三次,间隔三秒。这种异常的堆栈信息我是打印出来,其实可以用全局异常拦截的,在入库。
好了。
喜欢就点赞啊。

相关文章
|
5月前
|
SQL 监控 Java
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
这篇文章介绍了如何在IDEA和Spring Boot中使用AOP技术实现日志信息的记录到数据库的详细步骤和代码示例。
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
|
18天前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
68 14
|
2月前
|
监控 安全 Java
什么是AOP?如何与Spring Boot一起使用?
什么是AOP?如何与Spring Boot一起使用?
70 5
|
2月前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
56 1
|
3月前
|
架构师 Java 开发者
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
在40岁老架构师尼恩的读者交流群中,近期多位读者成功获得了知名互联网企业的面试机会,如得物、阿里、滴滴等。然而,面对“Spring Boot自动装配机制”等核心面试题,部分读者因准备不足而未能顺利通过。为此,尼恩团队将系统化梳理和总结这一主题,帮助大家全面提升技术水平,让面试官“爱到不能自已”。
得物面试:Springboot自动装配机制是什么?如何控制一个bean 是否加载,使用什么注解?
|
3月前
|
缓存 NoSQL Java
Springboot自定义注解+aop实现redis自动清除缓存功能
通过上述步骤,我们不仅实现了一个高度灵活的缓存管理机制,还保证了代码的整洁与可维护性。自定义注解与AOP的结合,让缓存清除逻辑与业务逻辑分离,便于未来的扩展和修改。这种设计模式非常适合需要频繁更新缓存的应用场景,大大提高了开发效率和系统的响应速度。
90 2
|
5月前
|
Java Spring 容器
SpringBoot整合AOP实现打印方法执行时间切面
SpringBoot整合AOP实现打印方法执行时间切面
57 1
|
5月前
|
安全 Java UED
掌握SpringBoot单点登录精髓,单点登录是一种身份认证机制
【8月更文挑战第31天】单点登录(Single Sign-On,简称SSO)是一种身份认证机制,它允许用户只需在多个相互信任的应用系统中登录一次,即可访问所有系统,而无需重复输入用户名和密码。在微服务架构日益盛行的今天,SSO成为提升用户体验和系统安全性的重要手段。本文将详细介绍如何在SpringBoot中实现SSO,并附上示例代码。
111 0
|
5月前
|
消息中间件 Java Kafka
深入SpringBoot的心脏地带:掌握其核心机制的全方位指南
【8月更文挑战第29天】这段内容介绍了在分布式系统中起到异步通信与解耦作用的消息队列,并详细探讨了三种流行的消息队列产品:RabbitMQ、RocketMQ 和 Kafka。RabbitMQ 是一个基于 AMQP 协议的开源消息队列系统,支持多种消息模型,具有高可靠性及稳定性;RocketMQ 则是由阿里巴巴开源的高性能分布式消息队列,支持事务消息等多种特性;而 Kafka 是 LinkedIn 开源的分布式流处理平台,以其高吞吐量和良好的可扩展性著称。文中还提供了使用这三种消息队列产品的示例代码。总之,这三款产品各有优势,适用于不同场景。
19 0
|
5月前
|
消息中间件 Java Kafka
SpringBoot大揭秘:如何轻松掌握其核心机制?
【8月更文挑战第29天】这段内容介绍了在分布式系统中起到异步通信与解耦作用的消息队列,并详细探讨了三种流行的消息队列产品:RabbitMQ、RocketMQ 和 Kafka。RabbitMQ 是一个基于 AMQP 协议的开源消息队列系统,支持多种消息模型,具有高可靠性及稳定性;RocketMQ 则是由阿里巴巴开源的高性能分布式消息队列,支持事务消息等多种特性;而 Kafka 是 LinkedIn 开源的分布式流处理平台,以其高吞吐量和良好的可扩展性著称。文中还提供了使用这三种消息队列产品的示例代码。
22 0