日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理
2023-04-18 14:57:29 时间
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 事件:
读取事件处理函数:
console 对应的 event handler:
transformed:
console 有专门对应的 transport 实现文件,位于 console.js 内:
从 data 字符串能看出在 console 打印彩色字符串的实现方式:
并没有像我想象的那样,执行到 82 行的 console.log
console 对象的 _stdout 属性,在 internal 这个 constructor.js 里注入:
这个 writeUtf8String 函数,是原生 native API:
位于 Node.js 源代码 的 internal/stream_base_common.js 内部:
writeUtf8String
stream_base_commons.js 文件位置如下:
https://github.com/nodejs/node/tree/master/lib/internal
native 实现:
https://github.com/nodejs/node/blob/master/lib/internal/stream_base_commons.js
this[kFs].write
相关文章
- EasyCVR对接华为iVS订阅摄像机和用户变更请求接口介绍
- 精选 | 腾讯云CDN内容加速场景有哪些?
- 模块化网络防止基于模型的多任务强化学习中的灾难性干扰
- 用搜索和注意力学习稳健的调度方法
- 用于多变量时间序列异常检测的学习图神经网络
- 助力政企自动化自然生长,华为WeAutomate RPA是怎么做到的?
- 使用腾讯轻量云搭建Fiora聊天室
- TSRC安全测试规范
- 云计算“功守道”
- 助力成本优化,腾讯全场景在离线混部系统Caelus正式开源
- Flink 利器:开源平台 StreamX 简介
- 腾讯云实践 | 一图揭秘腾讯碳中和?解决方案
- 深度学习中的轻量级网络架构总结与代码实现
- 信息系统项目管理师(高项复习笔记三)
- Adobe国际认证让科技赋能时尚
- c++该怎么学习(面试吃土记)
- 面试官问发布订阅模式是在问什么?
- 面试官:请实现一个通用函数把 callback 转成 promise
- 空中悬停、翻滚转身、成功着陆,我用强化学习「回收」了SpaceX的火箭
- 中山大学林倞解读视觉语义理解新趋势:从表达学习到知识及因果融合