@Data@AllArgsConstructorpublic class MsgEvent { private String msgId;}
@Component@Slf4jpublic class MsgListener { /** * value值表示当哪些异常的时候触发重试, * maxAttempts表示最大重试次数默认为3, * delay表示重试的延迟时间, * multiplier表示上一次延时时间是这一次的倍数。 * @param event */ @EventListener @Async @Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5)) public void sendMsg(MsgEvent event) { String msgId = event.getMsgId(); StopWatch watch = new StopWatch(msgId); watch.start(); log.info("开始发短信"); try { Thread.sleep(4000); } catch (InterruptedException e) { e.printStackTrace(); } watch.stop(); log.info("短信发送成功, 消息id:【{}】 | 耗时: ({})", msgId, watch.getLastTaskTimeMillis()); }}
添加@EnableAsync和@EnableRetry注解
@SpringBootApplication@EnableAsync@EnableRetrypublic class LabApplication { public static void main(String[] args) { SpringApplication.run(LabApplication.class, args); }}
@SpringBootTest@Slf4jpublic class EventTest { @Autowired private ApplicationContext applicationContext; @Test public void msgTest() { applicationContext.publishEvent(new MsgEvent("123")); log.info("短信发送事件发布成功"); try { Thread.sleep(6000); } catch (InterruptedException e) { e.printStackTrace(); } }}
留言与评论(共有 0 条评论) “” |