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 实例,然后调用它的方法(比如关闭连接等)。

相关推荐
软件技术NINI1 小时前
html css网页制作成品——HTML+CSS盐津铺子网页设计(5页)附源码
前端·css·html
mapbar_front2 小时前
面试问题—我的问题问完了,你还有什么想问我的吗?
前端·面试
quweiie2 小时前
thinkphp8+layui多图上传,带删除\排序功能
前端·javascript·layui
李鸿耀3 小时前
React 项目 SVG 图标太难管?用这套自动化方案一键搞定!
前端
闲蛋小超人笑嘻嘻3 小时前
树形结构渲染 + 选择(Vue3 + ElementPlus)
前端·javascript·vue.js
叶梅树3 小时前
从零构建A股量化交易工具:基于Qlib的全栈系统指南
前端·后端·算法
巴博尔3 小时前
uniapp的IOS中首次进入,无网络问题
前端·javascript·ios·uni-app
Asthenia04124 小时前
技术复盘:从一次UAT环境CORS故障看配置冗余的危害与最佳实践
前端
csj504 小时前
前端基础之《React(1)—webpack简介》
前端·react
被巨款砸中4 小时前
前端 20 个零依赖浏览器原生 API 实战清单
前端·javascript·vue.js·web