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())
  • 相关阅读:
    async和await是如何实现异步编程?
    HD-ACM算法专攻系列(23)——Crixalis's Equipment
    HD-ACM算法专攻系列(22)——Max Sum
    HD-ACM算法专攻系列(21)——Wooden Sticks
    HD-ACM算法专攻系列(20)——七夕节
    HD-ACM算法专攻系列(19)——Leftmost Digit
    搭建Prometheus平台,你必须考虑的6个因素
    实用教程丨使用K3s和MySQL运行Rancher 2.4
    Kubernetes Ingress简单入门
    一文讲透Cluster API的前世、今生与未来
  • 原文地址:https://www.cnblogs.com/aipeli/p/9975809.html
Copyright © 2011-2022 走看看