日志库 winston 的学习笔记 - logger.info 的实现原理单步调试

按照这篇文章日志库 winston 的学习笔记 - 创建一个使用 winston 的 Node.js 应用里的代码,对下列方法进行单步调试:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第1张图片
因为我们调用的是 info 方法,所以生成的日志,level 为 info:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第2张图片
第一个参数为 message,后面的都是 meta 信息:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第3张图片
在 info 的实现代码里,首先判断传入 log 方法的参数个数:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第4张图片
如果参数个数为 0 或者 1,有专门的实现。否则,进入 self.log:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第5张图片
构造 info 对象:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第6张图片

其中 msg 变量存储的是用户调用 info 方法传入的第一个参数,meta 是传递的第二个参数。

最后调用内部的 write 方法,传入的 message,是两个参数的连接。

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第7张图片
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第8张图片

encoding 是 utf8

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第9张图片
chunk:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第10张图片
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第11张图片

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第12张图片

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第13张图片

write 里面先 read,然后再 _transform:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第14张图片

format 我们选择的是 json format:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第15张图片

json.js 负责把 info 对象序列化成 json 字符串:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第16张图片

结果:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第17张图片

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第18张图片

addChunk:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第19张图片

emit:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第20张图片

三个 listeners:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第21张图片

data listener:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第22张图片

这里面看到了应用开发人员指定的 combined.log:

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第23张图片
writeOrBuffer:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第24张图片

_write 的注释:Writes the info object to our transport instance.

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第25张图片

好多递归操作:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第26张图片

准备投递到 fs stream 来写了:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第27张图片

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第28张图片

文件 transport 的写入逻辑:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第29张图片

这是 fs 的 native 实现了:
日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第30张图片

日志库 winston 的学习笔记 - logger.info 的实现原理单步调试_第31张图片

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

你可能感兴趣的:(日志库 winston 的学习笔记 - logger.info 的实现原理单步调试)