日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理


if (process.env.NODE_ENV !== 'production') {
    logger.add(new winston.transports.Console({
      format: winston.format.combine(
        winston.format.colorize({ all: true }),
        winston.format.simple()
    )}));
}

上述代码的含义是,如果当前 Node.js 执行环境不是生产环境,则将 winston 的输出,打印到控制台上。

_stream_readable.js 抛出 data 事件:

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第1张图片

读取事件处理函数:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第2张图片

console 对应的 event handler:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第3张图片

transformed:

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第4张图片

console 有专门对应的 transport 实现文件,位于 console.js 内:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第5张图片

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第6张图片

从 data 字符串能看出在 console 打印彩色字符串的实现方式:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第7张图片

并没有像我想象的那样,执行到 82 行的 console.log

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第8张图片

console 对象的 _stdout 属性,在 internal 这个 constructor.js 里注入:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第9张图片

这个 writeUtf8String 函数,是原生 native API:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第10张图片

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第11张图片

位于 Node.js 源代码 的 internal/stream_base_common.js 内部:

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第12张图片

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第13张图片

writeUtf8String

stream_base_commons.js 文件位置如下:

https://github.com/nodejs/nod...

日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第14张图片

native 实现:
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理_第15张图片

https://github.com/nodejs/nod...

this[kFs].write

更多Jerry的原创文章,尽在:"汪子熙":

你可能感兴趣的:(日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理)