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

Nest.js 重要的生命周期事件:

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

相关推荐
Roc.Chang4 分钟前
macos 使用 nvm 管理 node 并自定义安装目录
macos·node.js·nvm
yngsqq6 分钟前
c#使用高版本8.0步骤
java·前端·c#
Myli_ing40 分钟前
考研倒计时-配色+1
前端·javascript·考研
余道各努力,千里自同风43 分钟前
前端 vue 如何区分开发环境
前端·javascript·vue.js
软件小伟1 小时前
Vue3+element-plus 实现中英文切换(Vue-i18n组件的使用)
前端·javascript·vue.js
醉の虾1 小时前
Vue3 使用v-for 渲染列表数据后更新
前端·javascript·vue.js
张小小大智慧1 小时前
TypeScript 的发展与基本语法
前端·javascript·typescript
hummhumm2 小时前
第 22 章 - Go语言 测试与基准测试
java·大数据·开发语言·前端·python·golang·log4j
asleep7012 小时前
第8章利用CSS制作导航菜单
前端·css
hummhumm2 小时前
第 28 章 - Go语言 Web 开发入门
java·开发语言·前端·python·sql·golang·前端框架