zoukankan      html  css  js  c++  java
  • Nodejs 使用log4js日志

    一、创建log4.js文件,保存日志到log文件,并在控制台输出,如果不控制台输出,把删除红色的代码

    const log4js = require('log4js'),
            path = require('path')
     
    log4js.configure({
        replaceConsole: true,
        appenders: {
            stdout: {//控制台输出
                 type: 'console'
            },
            trace: {
                type: 'dateFile',
                filename: 'logs/tracelog/',
                pattern: 'trace-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
            debug: {
                type: 'dateFile',
                filename: 'logs/debuglog/',
                pattern: 'debug-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
            info: {
                type: 'dateFile',
                filename: 'logs/infolog/',
                pattern: 'info-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
            warn: {
                type: 'dateFile',
                filename: 'logs/warnlog/',
                pattern: 'warn-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
            error: {
                type: 'dateFile',
                filename: 'logs/errorlog/',
                pattern: 'error-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
            fatal: {
                type: 'dateFile',
                filename: 'logs/fatallog/',
                pattern: 'fatal-yyyy-MM-dd.log',
                alwaysIncludePattern: true
            },
        },
        categories: {
            trace: { appenders: ['stdout', 'trace'], level: 'trace' },//appenders:采用的appender,取appenders项,level:设置级别
            debug: { appenders: ['stdout', 'debug'], level: 'debug' },
            default: { appenders: ['stdout', 'info'], level: 'info' },
            warn: { appenders: ['stdout', 'warn'], level: 'warn' },
            error: { appenders: ['stdout', 'error'], level: 'error' },
            fatal: { appenders: ['stdout', 'fatal'], level: 'fatal' },
        }
    })
     
    exports.getLogger = function (name) {//name取categories项
        return log4js.getLogger(name || 'info')
    }
     
    exports.useLogger = function (app, logger) {//用来与express结合
        app.use(log4js.connectLogger(logger || log4js.getLogger('info'), {
            format: '[:remote-addr :method :url :status :response-timems][:referrer HTTP/:http-version :user-agent]'//自定义输出格式
        }))
    }

    二、引用log4.js调用

    const log4js  = require("../log4js/log4Builder"),
            logger  = log4js.getLogger("info")
    
            logger.info("现在时间:",new Date().toLocaleString())
            logger.trace("现在时间:",new Date().toLocaleString())
            logger.debug("现在时间:",new Date().toLocaleString())
            logger.info("现在时间:",new Date().toLocaleString())
            logger.warn("现在时间:",new Date().toLocaleString())
            logger.error("现在时间:",new Date().toLocaleString())
            logger.fatal("现在时间:",new Date().toLocaleString())
  • 相关阅读:
    CSS印象不深的小地方
    gulp常用插件的使用
    移动端手势库Hammer.js—增强touch事件或手势
    HTML5拖放与文件操作api,实现拖拽上传文件功能
    Less相关
    gulp使用(一)
    将博客搬至CSDN
    jquery Ajax 通过jsonp的方式跨域提交表单
    解决“The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path”问题
    使用eclipse4.5创建maven项目
  • 原文地址:https://www.cnblogs.com/aipeli/p/9975809.html
Copyright © 2011-2022 走看看