Egg.js 是什么?
Egg.js 为企业级框架和应用而生,我们希望由 Egg.js 孕育出更多上层框架,帮助开发团队和开发人员降低开发和维护成本。
注:Egg.js 缩写为 Egg
背景
组织为了更好的对各个业务的请求日志进行统一的分析,制定了统一的日志打印规范,比如:
[time][processId][traceId][userid] Hello World....
统一格式之后,业务现有业务的日志工具打印出来的格式是无法满足该规范的,所以我们需要对此进行改造。
我们前端目前Node中间层使用的框架是Egg.js,所以下文讲述下如何在Egg.js上自定义请求日志格式。
开始动手
Egg.js中自带了三种logger,分别是
Context Logger
App Logger
Agent Logger
Context Logger主要是用来记录请求相关的日志。每行日志都会在开头自动的记录当前请求的一些信息,比如时间、ip、请求url等等。
App Logger用于记录应用级别的日志,比如程序启动日志。
Agent Logger用于记录多进程模式运行下的日志。
我们想自定义请求级别的日志,那重点就要从Context Logger去研究怎么做。最理想的方案就是,Context Logger本身支持配置化的自定义格式,通过在egg.js的config配置文件中,通过传入formatter的参数就能自定义。
//config.default.js
exports.customLogger = {
log: {