首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Winston日志框架中实现Promise

在Winston日志框架中实现Promise
EN

Stack Overflow用户
提问于 2020-01-07 14:14:43
回答 1查看 553关注 0票数 0

如何在日志中实现Promise (下面的代码)

代码语言:javascript
复制
function logger(logFile) {
    return createLogger({
        level: loggerLevel === 'undefined' ? 'debug' : loggerLevel,
        format: format.combine(
            format.timestamp({
                format: 'YYYY-MM-DD HH:mm:ss'
            }),
            format.printf(info => `${info.timestamp} ${info.level}: ${info.message}`)),
        transports: [new transports.File({ filename: path.join(logDir, logFile) })]
    });
}

module.exports.logger = logger;

以及如何在此记录器的调用方中将其用作async/ await (代码示例如下)

代码语言:javascript
复制
const loggerForXYZ = logger('XYZ.log');
loggerForXYZ .log('info', 'test message log');
EN

回答 1

Stack Overflow用户

发布于 2020-01-07 17:36:51

您可以将日志记录部分包装在Promise.resolve中。就像这样。

代码语言:javascript
复制
log({ level, message } : {level: string, message: string }) {
    LoggerService.bottleneck.schedule({}, () => {
      return Promise.resolve(LoggerService.getLogger().log({ level, message }));
    });
  }

参考- https://github.com/winstonjs/winston/issues/1364#issuecomment-398404761

它讨论了如何使用bottleneckpromises

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59623118

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档