Spring Event 解耦業務

OoZzzy 2022-06-23 07:34:10 阅读数:482

springevent

解耦業務:

  • Aop
  • Event
  • Mq
  • agent

都是侵入性業務, 但是侵入性業務是不可避免的。

1.自定義事件

定義事件,繼承 ApplicationEvent 的類成為一個事件類

@Data
@ToString
public class OrderProductEvent extends ApplicationEvent {

/** 該類型事件攜帶的信息 */
private String orderId;
public OrderProductEvent(Object source, String orderId) {

super(source);
this.orderId = orderId;
}
}

2.定義監聽器

監聽並處理事件,實現 ApplicationListener 接口或者使用 @EventListener 注解

@Slf4j
@Component
public class OrderProductListener implements ApplicationListener<OrderProductEvent> {

/** 使用 onApplicationEvent 方法對消息進行接收處理 */
@SneakyThrows
@Override
public void onApplicationEvent(OrderProductEvent event) {

String orderId = event.getOrderId();
long start = System.currentTimeMillis();
Thread.sleep(2000);
long end = System.currentTimeMillis();
log.info("{}:校驗訂單商品價格耗時:({})毫秒", orderId, (end - start));
}
}

3.定義發布者

發布事件,通過 ApplicationEventPublisher 發布事件

@Slf4j
@Service
@RequiredArgsConstructor
public class OrderService {

/** 注入ApplicationContext用來發布事件 */
private final ApplicationContext applicationContext;
/** * 下單 * * @param orderId 訂單ID */
public String buyOrder(String orderId) {

long start = System.currentTimeMillis();
// 1.查詢訂單詳情
// 2.檢驗訂單價格 (同步處理)
applicationContext.publishEvent(new OrderProductEvent(this, orderId));
// 3.短信通知(异步處理)
long end = System.currentTimeMillis();
log.info("任務全部完成,總耗時:({})毫秒", end - start);
return "購買成功";
}
}

4.單測執行

@SpringBootTest
public class OrderServiceTest {

@Autowired private OrderService orderService;
@Test
public void buyOrderTest() {

orderService.buyOrder("732171109");
}
}
2022-04-24 10:13:17.535 INFO 44272 --- [ main] c.c.m.e.listener.OrderProductListener : 732171109:校驗訂單商品價格耗時:(2008)毫秒
2022-04-24 10:13:17.536 INFO 44272 --- [ main] c.c.mingyue.event.service.OrderService : 任務全部完成,總耗時:(2009)毫秒

5.Spring Event 异步使用

有些業務場景不需要在一次請求中同步完成,比如郵件發送、短信發送等。

5.1 自定義事件

@Data
@AllArgsConstructor
public class MsgEvent {

/** 該類型事件攜帶的信息 */
public String orderId;
}

5.2 2.定義監聽器

推薦使用 @EventListener 注解

@Slf4j
@Component
public class MsgListener {

@SneakyThrows
@EventListener(MsgEvent.class)
public void sendMsg(MsgEvent event) {

String orderId = event.getOrderId();
long start = System.currentTimeMillis();
log.info("開發發送短信");
log.info("開發發送郵件");
Thread.sleep(4000);
long end = System.currentTimeMillis();
log.info("{}:發送短信、郵件耗時:({})毫秒", orderId, (end - start));
}
}

5.3 定義發布者

/** * 下單 * * @param orderId 訂單ID */
public String buyOrder(String orderId) {

long start = System.currentTimeMillis();
// 1.查詢訂單詳情
// 2.檢驗訂單價格 (同步處理)
applicationContext.publishEvent(new OrderProductEvent(this, orderId));
// 3.短信通知(异步處理)
applicationContext.publishEvent(new MsgEvent(orderId));
long end = System.currentTimeMillis();
log.info("任務全部完成,總耗時:({})毫秒", end - start);
return "購買成功";
}

5.4 單測執行(同步)

@Test
public void buyOrderTest() {

orderService.buyOrder("732171109");
}

執行結果如下:

2022-04-24 10:24:13.905 INFO 54848 --- [ main] c.c.m.e.listener.OrderProductListener : 732171109:校驗訂單商品價格耗時:(2004)毫秒
2022-04-24 10:24:13.906 INFO 54848 --- [ main] c.c.mingyue.event.listener.MsgListener : 開發發送短信
2022-04-24 10:24:13.907 INFO 54848 --- [ main] c.c.mingyue.event.listener.MsgListener : 開發發送郵件
2022-04-24 10:24:17.908 INFO 54848 --- [ main] c.c.mingyue.event.listener.MsgListener : 732171109:發送短信、郵件耗時:(4002)毫秒
2022-04-24 10:24:17.908 INFO 54848 --- [ main] c.c.mingyue.event.service.OrderService :

5.5 開啟异步

啟動類增加 @EnableAsync 注解

@EnableAsync
@SpringBootApplication
public class MingYueSpringbootEventApplication {

public static void main(String[] args) {

SpringApplication.run(MingYueSpringbootEventApplication.class, args);
}
}

Listener 類需要開啟异步的方法增加 @Async 注解

@Async
@SneakyThrows
@EventListener(MsgEvent.class)
public void sendMsg(MsgEvent event) {

String orderId = event.getOrderId();
long start = System.currentTimeMillis();
log.info("開發發送短信");
log.info("開發發送郵件");
Thread.sleep(4000);
long end = System.currentTimeMillis();
log.info("{}:發送短信、郵件耗時:({})毫秒", orderId, (end - start));
}

5.6 單測執行(异步)

發送短信的線程顯示 task-1,主線程結束後(總耗時:(2017)毫秒)控制臺停止打印了

2022-04-24 10:30:59.002 INFO 59448 --- [ main] c.c.m.e.listener.OrderProductListener : 732171109:校驗訂單商品價格耗時:(2009)毫秒
2022-04-24 10:30:59.009 INFO 59448 --- [ main] c.c.mingyue.event.service.OrderService : 任務全部完成,總耗時:(2017)毫秒
2022-04-24 10:30:59.028 INFO 59448 --- [ task-1] c.c.mingyue.event.listener.MsgListener : 開發發送短信
2022-04-24 10:30:59.028 INFO 59448 --- [ task-1] c.c.mingyue.event.listener.MsgListener :
版权声明:本文为[OoZzzy]所创,转载请带上原文链接,感谢。 https://gsmany.com/2022/174/202206230641124049.html