打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

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

按照这篇文章日志库 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 实现了:

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
在Golang中配置Logrus
Node.js日志框架选型比较:Bunyan
前端在跳转传递参数过长或者含某些特殊字符时跳转失败或者传递参数被截断解决方法
postgresql之WAL(Write Ahead Log)
jmeter压测学习36-请求body自动签名带上sign参数
nodejs[0x01] -- Hello World
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服