Nest:应用生命周期事件详解

Nest 生命周期事件:

  1. onModuleInit
    当模块被初始化后触发。这个事件在模块的 providers 被创建之后,但在它们被使用之前触发。
  2. onModuleDestroy
    当模块被销毁前触发。这通常发生在应用程序关闭时,可以用来做一些清理工作,比如关闭数据库连接。
  3. onApplicationBootstrap
    当应用程序完全启动并且所有的模块都已初始化后触发。这是在整个应用程序加载完成后执行一些初始化逻辑的好时机。
  4. beforeApplicationShutdown
    这是 onApplicationShutdown 之前触发的事件,可以用来处理一些预清理工作。
  5. onApplicationShutdown
    当应用程序准备关闭时触发。你可以在这个事件中执行一些清理逻辑,比如优雅地关闭服务器。
  6. onRequest (中间件):
    虽然不是生命周期事件,但中间件可以在每个请求的生命周期中执行。它们在路由处理程序之前执行,可以进行请求日志记录、认证等操作。

Nest 启动时,会递归解析 Module 依赖,扫描其中的 provider、controller,注入它的依赖。

全部解析完后,会监听网络端口,开始处理请求。

过程中 Nest 暴露了一些生命周期方法:

  • 首先,递归初始化模块,会依次调用模块内的 controller、provider 的 onModuleInit 方法,然后再调用 module 的 onModuleInit 方法。
  • 全部初始化完之后,再依次调用模块内的 controller、provider 的 onApplicationBootstrap 方法,然后调用 module 的 onApplicationBootstrap 方法
  • 然后监听网络端口。之后 Nest 应用就正常运行了。

这个过程中,onModuleInit、onApplicationBootstrap 都是我们可以实现的生命周期方法。

在 module 实现它:

同理 controller、service 也这样实现。

最后输出的结果是:

应用销毁的时候也同样有生命周期:

  • 先调用每个模块的 controller、provider 的 onModuleDestroy 方法,然后调用 Module 的 onModuleDestroy 方法。
  • 之后再调用每个模块的 controller、provider 的 beforeApplicationShutdown 方法,然后调用 Module 的 beforeApplicationShutdown 方法。
  • 然后停止监听网络端口。
  • 之后调用每个模块的 controller、provider 的 onApplicationShutdown 方法,然后调用 Module 的 onApplicationShutdown 方法。
  • 之后停止进程。

beforeApplicationShutdown 里可以拿到 signal 系统信号的,比如 SIGTERM。

这些终止信号是别的进程传过来的,让它做一些销毁的事情,比如用 k8s 管理容器的时候,可以通过这个信号来通知它。

依次也在 controller、service 这样实现。

3s 后调用 app.close() 触发销毁。(只是触发销毁逻辑,但不会真正退出进程)

生命周期方法执行顺序:

而且所有的生命周期函数都是支持 async 的。

我们可以在 onApplicationShutdown 的生命周期里:

拿到当前模块的引用,调用 get 方法,传入 token,取出对应的 provider 实例,然后调用它的方法(比如关闭连接等)。

相关推荐
libraG14 分钟前
Jenkins打包问题
前端·npm·jenkins
前端康师傅14 分钟前
JavaScript 作用域
前端·javascript
前端缘梦14 分钟前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
我是天龙_绍23 分钟前
使用 TypeScript (TS) 结合 JSDoc
前端
云枫晖26 分钟前
JS核心知识-事件循环
前端·javascript
Simon_He26 分钟前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
eason_fan1 小时前
Git 大小写敏感性问题:一次组件重命名引发的CI构建失败
前端·javascript
无羡仙1 小时前
JavaScript 迭代器
前端
XiaoSong2 小时前
从未有过如此丝滑的React Native开发体验:EAS开发构建完全指南
前端·react.js
掘金者阿豪2 小时前
打通KingbaseES与MyBatis:一篇详尽的Java数据持久化实践指南
前端·后端