如何在项目中使用log4.js

pm2中自带的日志内容是不能满足日常的需求的,因此需要在项目中加上日志管理,这里研究了下log4的使用方法,效果挺好的,想要查看的都可以找到,记录下简单的使用步骤

log4的配合

// config.jslet path = require('path');// 日志根目录let baseLogPath = path.resolve(__dirname, '../../../logs');// 请求日志目录let reqPath = '/request';// 请求日志文件名let reqFileName = 'request';// 请求日志输出完整路径let reqLogPath = baseLogPath + reqPath + '/' + reqFileName;// 响应日志目录let resPath = '/response';// 响应日志文件名let resFileName = 'response';// 响应日志输出完整路径let resLogPath = baseLogPath + resPath + '/' + resFileName;// 错误日志目录let errPath = '/error';// 错误日志文件名let errFileName = 'error';// 错误日志输出完整路径let errLogPath = baseLogPath + errPath + '/' + errFileName;module.exports = {    appenders: {        // 所有的日志        'console': {type: 'console'},        // 请求日志        'reqLogger': {            type: 'dateFile', // 日志类型            filename: reqLogPath, // 输出文件名            pattern: '-yyyy-MM-dd-hh.log',  // 后缀            alwaysIncludePattern: true, // 上面两个参数是否合并            encoding: 'utf-8', // 编码格式            maxLogSize: 1000, // 最大存储内容        },        // 响应日志        'resLogger': {            type: 'dateFile',            filename: resLogPath,            pattern: '-yyyy-MM-dd-hh.log',            alwaysIncludePattern: true,            encoding: 'utf-8',            maxLogSize: 1000,        },        // 错误日志        'errLogger': {            type: 'dateFile',            filename: errLogPath,            pattern: '-yyyy-MM-dd-hh.log',            alwaysIncludePattern: true,            encoding: 'utf-8',            maxLogSize: 1000,        }    },    // 分类以及日志等级    categories: {        default: {            appenders: ['console'],            level: 'all'        },        reqLogger: {            appenders: ['reqLogger'],            level: 'info'        },        resLogger: {            appenders: ['resLogger'],            level: 'info'        },        errLogger: {            appenders: ['errLogger'],            level: 'error'        }    },}

log4的日志封装

这里是把log4封装成一个中间件,在app.js中直接调用就可以了
// 先安装log4js// log4.jsconst log4Config = require('./config')const log4js = require('log4js')// 调用配置文件log4js.configure(log4Config)class CommonHandle {    constructor(){}    // 格式化请求日志    static formatReqLog(ctx, time){        let text = '------------request start------------'        let method = ctx.method        text += `request method:  ${method} \n request url: ${ctx.originalUrl } \n`        if(method = 'GET'){            text += `request data: ${JSON.stringify(ctx.query)} \n`        }else{            text += `request data: ${JSON.stringify(ctx.body)} \n`        }        text += `ctx all: ${JSON.stringify(ctx)}`        return text    }    // 格式化相应日志    static formatResLog(ctx,time){        let text = '------------response start------------'        text += `response result: ${JSON.stringify(ctx.response.body)} \n`        text += `response all: ${JSON.stringify(ctx)} \n`        text += `response time: ${time} \n`        return text    }    // 格式化错误日志    static formatErrorLog(ctx,error,time){        let text = '------------error start------------'        text += this.formatResLog(ctx,time)        text += `error content: ${JSON.stringify(error)}`        return text    }}class HandleLogger extends CommonHandle{    constructor(){        super()    }    // 请求日志    static reqLogger(ctx){        log4js.getLogger('reqLogger').info(this.formatReqLog(ctx))    }    // 相应日志    static resLogger(ctx, time){        log4js.getLogger('resLogger').info(this.formatResLog(ctx,time))    }    // 错误日志    static errorLogger(ctx, error, time){        log4js.getLogger('errLogger').info(this.formatErrorLog(ctx,error,time))    }}module.exports = (options) => {    return async (ctx,next) => {        const startTime = new Date()        let period;        try{            // 请求日志            HandleLogger.reqLogger(ctx)            await next()            period = new Date() - startTime            // 响应日志            HandleLogger.resLogger(ctx,period)        }catch(err){            period = new Date() - startTime            // 错误日志            HandleLogger.errorLogger(ctx, err, period)        }    }}

调用封装好的日志函数

这里直接以中间件的形式调用就可以了

// app.jsconst Koa = require('koa')const app = new Koa()const LogJS = require('./common/log/log4')// log4.js引入app.use(LogJS())

最后部署上线之后就能直接在根目录下的logs文件夹下查看对应的日志内容。

链接地址