前言
使用spring事件机制能很好地帮助我们消除不同业务间的耦合关系,也可以提高执行效率,应该根据业务场景灵活选择.
spring事件发送监听涉及3个部分
ApplicationEvent:表示事件本身,自定义事件需要继承该类,可以用来传递数据
ApplicationListener:事件监听器接口,事件的业务逻辑封装在监听器里面.
ApplicationEventPublisherAware:事件发送器,通过实现这个接口,来触发事件.
-
在spring容器中是通过ApplicationEvent类和ApplicationListener接口来处理事件的.如果某个bean实现了ApplicationListener接口并被部署到容器中,
那么每次对应的ApplicationEvent被发布到容器中时,都会通知该bean.这是典型的观察者模式. -
spring的事件默认是同步的,即调用publisEvent()方法发布事件后, 它会处于阻塞状态,
直到onApplicationEvent接收到事件并处理完返回之后才会继续往下执行, 这种单线程同步的好处是可以进行事务管理. -
事件的异步发布机制参数ApplicationEventMulticaster文档.
Spring提供的标准事件
Event 说明
- ContextRefreshedEvent 当容器被实例化或refreshed时发布.如调用refresh()方法,
此处的实例化是指所有的bean都已被加载,后置处理器都被激活,所有单例bean都已被实例化, 所有的容器对象都已准备好可使用.
如果容器支持热重载,则refresh可以被触发多次(XmlWebApplicatonContext支持热刷新,而GenericApplicationContext则不支持) - ContextStartedEvent 当容器启动时发布,即调用start()方法, 已启用意味着所有的Lifecycle
bean都已显式接收到了start信号 - ContextStoppedEvent 当容器停止时发布,即调用stop()方法, 即所有的Lifecycle
bean都已显式接收到了stop信号 , 关闭的容器可以通过start()方法重启 - ContextClosedEvent 当容器关闭时发布,即调用close方法,
关闭意味着所有的单例bean都已被销毁.关闭的容器不能被重启或refresh - RequestHandledEvent 这只在使用spring的DispatcherServlet时有效,当一个请求被处理完成时发布
https://www.jianshu.com/p/e755b8163b9a
https://zhuanlan.zhihu.com/p/101128672