ScheduledExecutorService 周期性线程池
消息队列
redis有序集合
Quartz,job等定时任务框架
Timer
delayQueue
等等,我们该篇介绍的是 异步Async+延迟队列delayQueue 。
进入正题:
=========
一个简单的重试需求场景
我们服务端是个中间平台,
用户调用我们服务端下单成功,我们需要通知第三方平台发货。
但是这个通知发货有可能通知失败,我们允许最大失败次数是N次;
也就是说除了第一次通知发出后,我们需要进行额外的N次发货通知;
而且后面额外进行的N次发货通知是有延迟时间的, 每个之间的间隔都是动态设置的;
期间只要有一次通知成功了,那么我们就不再重新发送通知;
如果通知没发成功,就会根据我们设置的N次以及延迟时间,继续发送通知。
先创建一个异步线程池的配置类(如果你还不了解springboot使用异步线程的,可以先去看看我这篇文章:https://blog.csdn.net/qq_35387940/article/details/83991594),AsyncThreadConfig.class:
ps: 这里用的是spring提供的线程池
import org.springframework.context.annotation.Bean;
impor