依照这篇文章日志库 winston 的学习笔记 – 创立一个应用 winston 的 Node.js 利用里的代码,对下列办法进行单步调试:
因为咱们调用的是 info 办法,所以生成的日志,level 为 info:
第一个参数为 message,前面的都是 meta 信息:
在 info 的实现代码里,首先判断传入 log 办法的参数个数:
如果参数个数为 0 或者 1,有专门的实现。否则,进入 self.log:
结构 info 对象:
其中 msg 变量存储的是用户调用 info 办法传入的第一个参数,meta 是传递的第二个参数。
最初调用外部的 write 办法,传入的 message,是两个参数的连贯。
encoding 是 utf8
chunk:
write 外面先 read,而后再 _transform:
format 咱们抉择的是 json format:
json.js 负责把 info 对象序列化成 json 字符串:
后果:
addChunk:
emit:
三个 listeners:
data listener:
这外面看到了利用开发人员指定的 combined.log:
writeOrBuffer:
_write 的正文:Writes the info object to our transport instance.
好多递归操作:
筹备投递到 fs stream 来写了:
文件 transport 的写入逻辑:
这是 fs 的 native 实现了:
更多 Jerry 的原创文章,尽在:” 汪子熙 ”: