美文网首页收藏
日志库 winston 的学习笔记 - logger.info

日志库 winston 的学习笔记 - logger.info

作者: 华山令狐冲 | 来源:发表于2021-11-23 07:35 被阅读0次

按照这篇文章日志库 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的原创文章,尽在:"汪子熙":


相关文章

网友评论

    本文标题:日志库 winston 的学习笔记 - logger.info

    本文链接:https://www.haomeiwen.com/subject/lwhqaltx.html