前言:
在微服务领域, 一种通信方法是synchronous(同步)。事实是我们无法避免网络故障,临时服务停机(由于重启或崩溃)。当客户端需要实时数据且下游服务暂时没有响应时,它可能会影响用户体验,因此应该创建重试机制,Java中提供了许多解决方案选项。
-
重试可能会导致资源堵塞从而阻止应用程序恢复; 因此,重试次数必须有限如3,不超过5次左右。
-
不应对每个例外进行重试。它应该仅针对特定类型的异常进行编码。例如,不要在Exception.class周围放置代码,而是为SQLException.class执行此操作。
-
重试可能导致多个线程尝试访问相同的共享资源,锁可能是一个大问题。必须应用指数退避算法来持续增加重试之间的延迟,直到达到最大限制。
-
在应用重试时,必须处理幂等性。再次触发相同的请求不应该触发系统中的重复事务。
现在构建一个简单的服务,展示Spring Retry如何帮助解决Retry问题。