エンタープライズレベルのノードフレームワークとして、egg はカプセル化に基づくいくつかのルールに合意し、それをフレームワークに統合しました。プラグイン、サービス、拡張など。同時に、egg はユーザーがアプリケーションの起動プロセスによりよく参加できるようにするために、一連のライフサイクル メカニズムを実装します。
Egg ライフサイクルは統合されたエントリ ファイル app.js を提供し、このファイルはブート クラスを返し、さまざまなライフ サイクル関数がブート クラスで提供されます。
構成ファイルのロード、ファイルのロード、プラグインの起動、ワーカーの準備完了、アプリケーションの起動とシャットダウンまで、合計 7 つのライフ サイクルがあります。詳細は次のとおりです。
1. configWillLoad 構成ファイルがロードされようとしています。構成はこのライフサイクルで動的に変更できます。
2、configDidLoad設定ファイルの読み込みが完了しました
3.didLoadファイルのロードが完了しました
4. willReadyプラグインが開始されます
5.didReady ワーカーの準備が完了しました
6.serverDidReady アプリケーションが開始されます
7、beforeClose アプリケーションが終了しようとしています
例:
// app.js
class AppBootHook {
constructor(app) {
this.app = app;
}
configWillLoad() {
// 此时 config 文件已经被读取并合并,但是还并未生效
// 这是应用层修改配置的最后时机
// 注意:此函数只支持同步调用
// 例如:参数中的密码是加密的,在此处进行解密
this.app.config.mysql.password = decrypt(this.app.config.mysql.password);
// 例如:插入一个中间件到框架的 coreMiddleware 之间
const statusIdx = this.app.config.coreMiddleware.indexOf('status');
this.app.config.coreMiddleware.splice(statusIdx + 1, 0, 'limit');
}
async didLoad() {
// 所有的配置已经加载完毕
// 可以用来加载应用自定义的文件,启动自定义的服务
// 例如:创建自定义应用的示例
this.app.queue = new Queue(this.app.config.queue);
await this.app.queue.init();
// 例如:加载自定义的目录
this.app.loader.loadToContext(path.join(__dirname, 'app/tasks'), 'tasks', {
fieldClass: 'tasksClasses',
});
}
async willReady() {
// 所有的插件都已启动完毕,但是应用整体还未 ready
// 可以做一些数据初始化等操作,这些操作成功才会启动应用
// 例如:从数据库加载数据到内存缓存
this.app.cacheData = await this.app.model.query(QUERY_CACHE_SQL);
}
async didReady() {
// 应用已经启动完毕
const ctx = await this.app.createAnonymousContext();
await ctx.service.Biz.request();
}
async serverDidReady() {
// http / https server 已启动,开始接受外部请求
// 此时可以从 app.server 拿到 server 的实例
this.app.server.on('timeout', socket => {
// handle socket timeout
});
}
}
module.exports = AppBootHook;