序
本文主要介紹下如何在spring中進(jìn)行發(fā)布時間以及接收事件
定義事件
public class DemoEvent extends ApplicationEvent {
private String message;
public DemoEvent(Object source, String message) {
super(source);
this.message = message;
}
public String getMessage() {
return message;
}
}
發(fā)布事件
@Autowired
private ApplicationEventPublisher applicationEventPublisher;
@GetMapping("/send-event")
public Object sendEvent(@RequestParam String msg){
DemoEvent demoEvent = new DemoEvent(this,msg);
applicationEventPublisher.publishEvent(demoEvent);
LOGGER.info("finish publish event");
return "success";
}
這里在mvc中發(fā)布绿饵,僅僅是為了演示。
接收事件(默認(rèn)同步
)
@Component
public class DemoEventListener implements ApplicationListener<DemoEvent>{
private static final Logger LOGGER = LoggerFactory.getLogger(DemoEventListener.class);
@Override
public void onApplicationEvent(DemoEvent demoEvent) {
LOGGER.info("receive event:{}",demoEvent.getMessage());
}
}
這里是同步接收
異步處理事件
@Configuration
public class AsyncEventConfig {
@Bean(name = "applicationEventMulticaster")
public ApplicationEventMulticaster simpleApplicationEventMulticaster() {
SimpleApplicationEventMulticaster eventMulticaster
= new SimpleApplicationEventMulticaster();
eventMulticaster.setTaskExecutor(new SimpleAsyncTaskExecutor());
return eventMulticaster;
}
}
加上這個配置就ok了诗轻,不然要注意,這里自己new的task executor,要優(yōu)雅關(guān)閉的話东跪,需要自己shutdown
SimpleApplicationEventMulticaster
spring-context-4.3.11.RELEASE-sources.jar!/org/springframework/context/event/SimpleApplicationEventMulticaster.java
@Override
public void multicastEvent(ApplicationEvent event) {
multicastEvent(event, resolveDefaultEventType(event));
}
@Override
public void multicastEvent(final ApplicationEvent event, ResolvableType eventType) {
ResolvableType type = (eventType != null ? eventType : resolveDefaultEventType(event));
for (final ApplicationListener<?> listener : getApplicationListeners(event, type)) {
Executor executor = getTaskExecutor();
if (executor != null) {
executor.execute(new Runnable() {
@Override
public void run() {
invokeListener(listener, event);
}
});
}
else {
invokeListener(listener, event);
}
}
}
private ResolvableType resolveDefaultEventType(ApplicationEvent event) {
return ResolvableType.forInstance(event);
}
可以看到,使用applicationEventMulticaster的時候鹰溜,如果有線程池虽填,則用線程池異步執(zhí)行;否則則知直接調(diào)用listener的執(zhí)行方法同步執(zhí)行曹动。