日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

log4js linux,如何在项目中使用log4.js的方法步骤

發布時間:2025/3/15 linux 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 log4js linux,如何在项目中使用log4.js的方法步骤 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

pm2中自帶的日志內容是不能滿足日常的需求的,因此需要在項目中加上日志管理,這里研究了下log4的使用方法,效果挺好的,想要查看的都可以找到,記錄下簡單的使用步驟

log4的配合

// config.js

let 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.js

const 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.js

const Koa = require('koa')

const app = new Koa()

const LogJS = require('./common/log/log4')

// log4.js引入

app.use(LogJS())

最后部署上線之后就能直接在根目錄下的logs文件夾下查看對應的日志內容。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的log4js linux,如何在项目中使用log4.js的方法步骤的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。