• log4js使用笔记


    1. 前言

    本文将介绍笔者log4j时的一些笔记,以期协助读者规避一些问题。

    2. 使用步骤

    2.1 配置logjs

    // src/config/log4js.config.js

    /**
     * 内置两种布局:my:console(针对控制台、终端)、my:basic(针对文件)
     *
     * 代码:
       const log4js = require('log4js')
       const log4jsConfig = require('@/config/log4js.config')
       log4js.configure(log4jsConfig)
     */
    const path = require('path')
    const log4js = require('log4js')
    const { Logger } = require('s-utils')
    
    // 配置应用名(英文)数组,根据配置的应用名,生成 appenders 、categories
    const appNames = ['nginx', 'tomcat']
    
    /**
     * 添加控制台的简单布局
     */
    log4js.addLayout('my:console', function (config) {
      return function (event) {
        const { type, message } = event.data[0]
        return `${type}: ${message}`
      }
    })
    
    /**
     * 添加基础布局
     */
    log4js.addLayout('my:basic', function (config) {
      return function (event) {
        return JSON.stringify(event.data[0])
      }
    })
    
    const appenders = {
      'my:stdout': {
        type: 'stdout',
        layout: { type: 'my:console', separator: ',' },
      },
      'my:console': {
        type: 'console',
        layout: { type: 'my:console', separator: ',' },
      },
    }
    const categories = {
      default: {
        appenders: ['my:console', 'my:stdout'],
        level: 'debug',
        enableCallStack: false,
      },
    }
    for (const appName of appNames) {
      appenders[appName] = {
        type: 'dateFile',
        filename: path.join(Logger.getDefaultDirPath(appName), appName),
        maxLogSize: 2000,
        pattern: 'yyyy-MM-dd.txt',
        alwaysIncludePattern: true,
        backups: 100,
        compress: false,
        layout: {
          type: 'my:basic',
        },
      }
      categories[appName] = {
        appenders: [appName, 'my:console', 'my:stdout'],
        level: 'debug',
        enableCallStack: false,
      }
    }
    
    module.exports = {
      appenders,
      categories,
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75

    2.2 log4js基础类

    // src/logger/index.js

    // https://github.com/log4js-node/log4js-example/blob/master/config/log4js.json
    // https://log4js-node.github.io/log4js-node/file.html
    const log4js = require('log4js')
    const moment = require('moment')
    const path = require('path')
    const { OSUtils, CryptoUtils } = require('s-utils')
    
    /**
     * @class Logger
     * @classdesc 日志基础类
     */
    module.exports = class Logger {
      static INFO = 'info'
      static ERROR = 'error'
      static WARN = 'warn'
      static DEBUG = 'debug'
    
      /**
       * Creates an instance of Logger.
       * @param {string} [appName='log4js'] 应用名称(英文)
       * @memberof Logger
       */
      constructor (appName = 'log4js') {
        // 应用的名称(英文)
        this.appName = ''
        // 日志信息数组
        this.logs = []
        // 当前日志的ID
        this.id = 0
        // log4js实例
        this.logger4js = null
        this.appName = appName
        this.logger4js = this.getLog4jsLogger()
      }
      /**
       * 获取默认日志目录路径
       *
       * @param {string} appName 应用的名称(英文名)
       * @returns {string}
       * @memberof Logger
       */
      static getDefaultDirPath (appName) {
        return path.join(OSUtils.getHomeDirPath(), `logs/${appName}`)
      }
      /**
       * 获取log4js日志实例
       *
       * @returns {object}
       * @memberof Logger
       */
      getLog4jsLogger () {
        return log4js.getLogger(this.appName)
      }
      /**
       * 获取当前日志数组
       *
       * @returns {object[]} 当前日志数组
       * @memberof Logger
       */
      getLogs () {
        return this.logs
      }
      /**
       * 清空当前日志数组
       *
       * @memberof Logger
       */
      emptyLogs () {
        this.logs.length = 0
      }
      /**
       * 生成日志
       *
       * @param {string} type 日志类型
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @returns {object} 日志信息对象
       * @memberof Logger
       */
      generateLogInfo (type, message, extraData = {}) {
        const time = moment().format('YYYY-MM-DD HH:mm:ss')
        const logInfo = {
          // 取md5值
          id: CryptoUtils.md5(`${this.id}-${time}`),
          type,
          message,
          time,
          extraData,
        }
        this.id++
        return logInfo
      }
      /**
       * 记录日志
       *
       * @param {string} type 日志类型
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @memberof Logger
       */
      log (type, message, extraData = {}) {
        var _a
        // 内容为空时,不展示日志
        if (
          !((_a =
            message === null || message === void 0 ? void 0 : message.trim) ===
            null || _a === void 0
            ? void 0
            : _a.call(message))
        ) {
          return
        }
        const log = this.generateLogInfo(type, message, extraData)
        // 类型对应的日志函数为空时,使用info函数
        const logFn = this.logger4js[type]
          ? this.logger4js[type]
          : this.logger4js.info
        logFn.call(this.logger4js, log)
        this.logs.push(log)
      }
      /**
       * 记录常规日志
       *
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @memberof Logger
       */
      info (message, extraData = {}) {
        this.log(Logger.INFO, message, extraData)
      }
      /**
       * 记录错误日志
       *
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @memberof Logger
       */
      error (message, extraData = {}) {
        this.log(Logger.ERROR, message, extraData)
      }
      /**
       * 记录警告日志
       *
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @memberof Logger
       */
      warn (message, extraData = {}) {
        this.log(Logger.WARN, message, extraData)
      }
      /**
       * 记录调试日志
       *
       * @param {string} message 日志内容
       * @param {object} [extraData={}] 额外的数据,json对象
       * @memberof Logger
       */
      debug (message, extraData = {}) {
        this.log(Logger.DEBUG, message, extraData)
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135
    • 136
    • 137
    • 138
    • 139
    • 140
    • 141
    • 142
    • 143
    • 144
    • 145
    • 146
    • 147
    • 148
    • 149
    • 150
    • 151
    • 152
    • 153
    • 154
    • 155
    • 156
    • 157
    • 158
    • 159
    • 160
    • 161

    2.3 创建logger实例

    2.3.1 配置log4js

    在业务项目的入口文件,配置log4js。必须要先配置后使用。

    // src/main.js

    const log4js = require('log4js')
    const log4jsConfig = require('@/config/log4js.config')
    log4js.configure(log4jsConfig)
    
    • 1
    • 2
    • 3

    2.3.2 创建实例

    const logger = new Logger('nginx')
    logger.info('This is test info.', { addtional: 'test' })
    
    • 1
    • 2

    特别说明:
    OSUtils, CryptoUtils是笔者自己工具库里的工具函数,可根据需要使用其他方式来替换。

    3. 常见问题

    ##. 3.1 按照如上步骤配置log4js之后,并未如期记录日志

    请检查是否使用了类似webpack之类的打包工具。如果使用了,再检查Logger是否适合业务项目一起构建的,如果Logger类是单独构建的,就会导致所做的配置不会生效。因为按照log4js的规则,若要对它正确配置,必须要确保配置时和使用时,在运行的时候是同一个log4js库,如果使用了webpack并且Logger类是单独构建的,单独构建的Logger类里的log4js和业务项目里的log4js不是同一个实例,在业务项目里做的配置,就不会生效。

  • 相关阅读:
    多测师肖sir_高级金牌讲师__git讲解
    玩转HarmonyOS专项测试,轻松上架“五星”高品质应用
    什么是 ping (ICMP) 洪水 DDOS 攻击?
    刷完HashMap源码,我们一起进大厂
    概率论的学习和整理9:超几何分布--未完成
    spring复习05,spring整合mybatis,声明式事务
    端到端测试(End-to-end tests)重试策略
    [极客大挑战 2019]FinalSQL - 异或盲注
    Unity判断两个物体在XZ平面上的夹角(战双露西亚图文讲解)
    贪心算法(1)--经典贪心算法
  • 原文地址:https://blog.csdn.net/u011818572/article/details/125551471