加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
app.js 2.62 KB
一键复制 编辑 原始数据 按行查看 历史
Fate 提交于 2021-12-11 15:46 . 更新rabbitMq调用
class AppBootHook {
constructor(app) {
this.app = app;
app.messenger.on('egg-ready', () => {
app.logger.info('all worker is ready', process.pid);
});
}
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();
// 自动缓存配置
// ctx.service.dic.dic.initProject();
}
async serverDidReady() {
// http / https server 已启动,开始接受外部请求
// 此时可以从 app.server 拿到 server 的实例
const ctx = await this.app.createAnonymousContext();
// DLX 类型的 队列配置
const { exchange, queue, exchangeDLX, routingKeyDLX, queueDLX } = this.app.config.rabbit.working;
// DLX 类型的 延迟消息队列
this.app.config.amqplib.enable && await ctx.utils.rabbitMq.dlx.consume.run(
this.app.config.amqplib.connect, // 连接配置
{ exchange, queue, exchangeDLX, routingKeyDLX, queueDLX }, // 队列配置
async (...args) => ctx.service.mq.consume.consume(...args), // 处理消费者消息
(...args) => ctx.logger.info(...args), // 添加文件日志
() => ctx.service.utils.alarm.dingDingRobot(this.app.config.alarm.dinDing.consumeError, '队列消息已达最大尝错次数,请检查逻辑!!') // 容错报警
);
}
}
module.exports = AppBootHook;
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化