成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot:Event實現發布/訂閱模式

開發 架構
不管是否基于spring boot 的發布訂閱模型,最終都是開啟了線程執行任務,和使用第三方的MQ消息組件,問題在于重啟服務器或者未知原因崩潰的時候,消息的恢復機制要自行處理。

如圖所示支付業務中,用戶支付成功之后,后續還有很多的業務流程,但是對于用戶來講是透明的,所以為了提高接口的響應速率,提高用戶體驗,后續操作都會選擇異步執行

異步執行方式

異步執行主體

@Service
public class OrderService {
public void orderSuccess(){

// 訂單完成異步任務開啟 可以再統一封裝
Order order = new Order();
order.setOrderNo(String.valueOf(System.currentTimeMillis()));
Map<String, OrderSuccessService> orderSuccessServiceMap = SpringContextUtil.getBeansOfType(OrderSuccessService.class);
orderSuccessServiceMap.values().forEach(service -> {
service.orderSuccess(order);
});
}
}

異步執行接口

public interface OrderSuccessService {
/**
* 訂單支付成功
* @param order
*/
public CompletableFuture<Boolean> orderSuccess(Order order);
}
@Slf4j
@Service
public class MerchantNoticeServiceImpl implements OrderSuccessService {
@Override
@Async("taskExecutor")
public CompletableFuture<Boolean> orderSuccess(Order order) {
log.info("{}商戶通知:{}",Thread.currentThread(),order);
// 返回異步調用的結果
return CompletableFuture.completedFuture(true);
}
}
@Slf4j
@Service
public class MerchantNoticeServiceImpl implements OrderSuccessService {
@Override
@Async("taskExecutor")
public CompletableFuture<Boolean> orderSuccess(Order order) {
log.info("{}商戶通知:{}",Thread.currentThread(),order);
// 返回異步調用的結果
return CompletableFuture.completedFuture(true);
}
}
@Slf4j
@Service
public class MerchantNoticeServiceImpl implements OrderSuccessService {
@Override
@Async("taskExecutor")
public CompletableFuture<Boolean> orderSuccess(Order order) {
log.info("{}商戶通知:{}",Thread.currentThread(),order);
// 返回異步調用的結果
return CompletableFuture.completedFuture(true);
}
}

自定義線程池,線程池隔離,開啟異步任務執行

@Configuration // 配置類
@EnableAsync // @Async注解能夠生效
public class TaskConfiguration {
@Bean("taskExecutor")
public Executor taskExecutor(){
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
// 線程池創建時候初始化的線程數
executor.setCorePoolSize(5);
// 線程池最大的線程數,只有在緩沖隊列滿了之后,才會申請超過核心線程數的線程
executor.setMaxPoolSize(10);
// 用來緩沖執行任務的隊列
executor.setQueueCapacity(200);
// 當超過了核心線程之外的線程,在空閑時間到達之后會被銷毀
executor.setKeepAliveSeconds(60);
// 可以用于定位處理任務所在的線程池
executor.setThreadNamePrefix("taskExecutor-orderSuccess-");
// 這里采用CallerRunsPolicy策略,當線程池沒有處理能力的時候,該策略會直接在execute方法的調用線程中運行被拒絕的任務;
// 如果執行程序已關閉,則會丟棄該任務
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
// 設置 線程池關閉 的時候 等待 所有任務都完成后,再繼續 銷毀 其他的 Bean,
// 這樣這些 異步任務 的 銷毀 就會先于 數據庫連接池對象 的銷毀。
executor.setWaitForTasksToCompleteOnShutdown(true);
// 該方法用來設置線程池中 任務的等待時間,如果超過這個時間還沒有銷毀就 強制銷毀,以確保應用最后能夠被關閉,而不是阻塞住。
executor.setAwaitTerminationSeconds(60);
return executor;
}
}

Spring Event實現發布/訂閱模式

自定義事件:通過繼承ApplicationEve?

nt,并重寫構造函數,實現事件擴展。

public class OrderApplicationEvent extends ApplicationEvent {
public OrderApplicationEvent(OrderData orderData){
super(orderData);
}
}

定義事件的消息體

@Data
public class OrderData {
/**
* 訂單號
*/
private String orderNo;
}

事件監聽

@Slf4j
@Service
public class MerchantNoticeListener {
@Async("asyncEventTaskExecutor")
@EventListener
public CompletableFuture<Boolean> orderSuccess(OrderApplicationEvent event) {
log.info("{}商戶通知:{}",Thread.currentThread(),event);
// 返回異步調用的結果
return CompletableFuture.completedFuture(true);
}
}
@Slf4j
@Service
public class UserNoticeListener implements ApplicationListener<OrderApplicationEvent> {
@Override
@Async("asyncEventTaskExecutor")
public void onApplicationEvent(OrderApplicationEvent event) {
log.info("{}用戶通知:{}",Thread.currentThread(),event);
}
}
@Slf4j
@Service
public class UserNoticeListener implements ApplicationListener<OrderApplicationEvent> {
@Override
@Async("asyncEventTaskExecutor")
public void onApplicationEvent(OrderApplicationEvent event) {
log.info("{}用戶通知:{}",Thread.currentThread(),event);
}
}
@Slf4j
@Service
public class UserNoticeListener implements ApplicationListener<OrderApplicationEvent> {
@Override
@Async("asyncEventTaskExecutor")
public void onApplicationEvent(OrderApplicationEvent event) {
log.info("{}用戶通知:{}",Thread.currentThread(),event);
}
}

自定義線程池

@Configuration
@Slf4j
@EnableAsync // @Async注解能夠生效
public class AsyncConfiguration implements AsyncConfigurer {
@Bean("asyncEventTaskExecutor")
public ThreadPoolTaskExecutor executor(){
//Spring封裝的一個線程池
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(5);
executor.setMaxPoolSize(50);
executor.setQueueCapacity(30);
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
executor.setThreadNamePrefix("asyncEventTaskExecutor--orderSuccess-");
executor.initialize();
return executor;
}

@Override
public Executor getAsyncExecutor(){
return executor();
}

/**
* 異常處理
* @return
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler(){
return (ex, method, params) -> log.error(String.format("[async] task{} error:", method), ex);
}
}

事件發布

@Service
@Slf4j
public class OrderEventService {
private final ApplicationEventPublisher applicationEventPublisher;

public OrderEventService(ApplicationEventPublisher applicationEventPublisher){
this.applicationEventPublisher = applicationEventPublisher;
}
public void success(){
OrderData orderData = new OrderData();
orderData.setOrderNo(String.valueOf(System.currentTimeMillis()));
// 消息
OrderApplicationEvent orderApplicationEvent = new OrderApplicationEvent(orderData);
// 發布事件
applicationEventPublisher.publishEvent(orderApplicationEvent);
}
}

寫在最后:不管是否基于spring boot 的發布訂閱模型,最終都是開啟了線程執行任務,和使用第三方的MQ消息組件,問題在于重啟服務器或者未知原因崩潰的時候,消息的恢復機制要自行處理。

建議使用在一些邊緣業務,比如記錄日志,這些要求沒有那么高的業務。

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2022-06-27 13:56:10

設計模式緩存分布式系統

2024-07-02 11:42:53

SpringRedis自定義

2025-01-09 11:15:47

2023-11-10 09:22:06

2009-11-05 10:07:37

WCF設計模式

2024-07-29 08:34:18

C++訂閱者模式線程

2025-02-25 09:29:34

2023-03-03 12:39:25

MQTT工廠模式

2024-03-28 08:07:42

RabbitMQ訂閱模式

2024-05-14 08:03:51

C#EventArgs?屬性

2021-08-02 17:21:08

設計模式訂閱

2024-01-10 08:16:08

Redis集成JMS

2023-12-04 08:24:23

2020-09-15 10:25:13

Redis命令Java

2025-03-11 09:30:00

2022-08-15 09:02:22

Redis模式訂閱消息

2010-03-02 16:28:11

WCF發布訂閱

2022-07-13 08:36:57

MQ架構設計模式

2023-12-14 10:10:09

pythonRedis開發

2022-09-19 16:08:31

Dapr發布訂閱
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一区二区三区在线观看视频 | 国精产品一品二品国精在线观看 | 青青草综合网 | 欧美一区免费 | 国产日韩视频在线 | 欧美激情一区二区三级高清视频 | 国产精品视频网 | 91 在线 | 久久精品视频12 | 黄色毛片大全 | 日韩成人精品在线观看 | 国产日韩欧美一区二区 | 欧美一区二区三区在线看 | 亚洲视频自拍 | 狠狠操狠狠干 | 天天看天天操 | 国产亚洲第一页 | 免费激情 | 国产精品伦理一区二区三区 | 国产精品九九视频 | 色就是色欧美 | 欧美mv日韩mv国产网站91进入 | 亚洲精品免费视频 | 国产精品三级 | 精品一区二区三区在线观看 | 国产亚洲高清视频 | 在线免费观看日本 | 天天干天天干 | 中文字幕视频在线看 | 午夜男人的天堂 | 日韩在线视频一区二区三区 | 91免费在线 | 岛国av免费看 | 在线第一页 | 一区二区三区不卡视频 | 国产目拍亚洲精品99久久精品 | 视频在线一区 | 国产在线aa | 毛片区| 日日夜夜精品视频 | 国产在线观看一区二区 |