如何在項(xiàng)目中使用log4.js的方法步驟
pm2中自帶的日志內(nèi)容是不能滿足日常的需求的,因此需要在項(xiàng)目中加上日志管理,這里研究了下log4的使用方法,效果挺好的,想要查看的都可以找到,記錄下簡(jiǎn)單的使用步驟
log4的配合
// config.js
let path = require('path');
// 日志根目錄
let baseLogPath = path.resolve(__dirname, '../../../logs');
// 請(qǐng)求日志目錄
let reqPath = '/request';
// 請(qǐng)求日志文件名
let reqFileName = 'request';
// 請(qǐng)求日志輸出完整路徑
let reqLogPath = baseLogPath + reqPath + '/' + reqFileName;
// 響應(yīng)日志目錄
let resPath = '/response';
// 響應(yīng)日志文件名
let resFileName = 'response';
// 響應(yīng)日志輸出完整路徑
let resLogPath = baseLogPath + resPath + '/' + resFileName;
// 錯(cuò)誤日志目錄
let errPath = '/error';
// 錯(cuò)誤日志文件名
let errFileName = 'error';
// 錯(cuò)誤日志輸出完整路徑
let errLogPath = baseLogPath + errPath + '/' + errFileName;
module.exports = {
appenders: {
// 所有的日志
'console': {type: 'console'},
// 請(qǐng)求日志
'reqLogger': {
type: 'dateFile', // 日志類型
filename: reqLogPath, // 輸出文件名
pattern: '-yyyy-MM-dd-hh.log', // 后綴
alwaysIncludePattern: true, // 上面兩個(gè)參數(shù)是否合并
encoding: 'utf-8', // 編碼格式
maxLogSize: 1000, // 最大存儲(chǔ)內(nèi)容
},
// 響應(yīng)日志
'resLogger': {
type: 'dateFile',
filename: resLogPath,
pattern: '-yyyy-MM-dd-hh.log',
alwaysIncludePattern: true,
encoding: 'utf-8',
maxLogSize: 1000,
},
// 錯(cuò)誤日志
'errLogger': {
type: 'dateFile',
filename: errLogPath,
pattern: '-yyyy-MM-dd-hh.log',
alwaysIncludePattern: true,
encoding: 'utf-8',
maxLogSize: 1000,
}
},
// 分類以及日志等級(jí)
categories: {
default: {
appenders: ['console'],
level: 'all'
},
reqLogger: {
appenders: ['reqLogger'],
level: 'info'
},
resLogger: {
appenders: ['resLogger'],
level: 'info'
},
errLogger: {
appenders: ['errLogger'],
level: 'error'
}
},
}
log4的日志封裝
這里是把log4封裝成一個(gè)中間件,在app.js中直接調(diào)用就可以了
// 先安裝log4js
// log4.js
const log4Config = require('./config')
const log4js = require('log4js')
// 調(diào)用配置文件
log4js.configure(log4Config)
class CommonHandle {
constructor(){}
// 格式化請(qǐng)求日志
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
}
// 格式化相應(yīng)日志
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
}
// 格式化錯(cuò)誤日志
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()
}
// 請(qǐng)求日志
static reqLogger(ctx){
log4js.getLogger('reqLogger').info(this.formatReqLog(ctx))
}
// 相應(yīng)日志
static resLogger(ctx, time){
log4js.getLogger('resLogger').info(this.formatResLog(ctx,time))
}
// 錯(cuò)誤日志
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{
// 請(qǐng)求日志
HandleLogger.reqLogger(ctx)
await next()
period = new Date() - startTime
// 響應(yīng)日志
HandleLogger.resLogger(ctx,period)
}catch(err){
period = new Date() - startTime
// 錯(cuò)誤日志
HandleLogger.errorLogger(ctx, err, period)
}
}
}
調(diào)用封裝好的日志函數(shù)
這里直接以中間件的形式調(diào)用就可以了
// app.js
const Koa = require('koa')
const app = new Koa()
const LogJS = require('./common/log/log4')
// log4.js引入
app.use(LogJS())
最后部署上線之后就能直接在根目錄下的logs文件夾下查看對(duì)應(yīng)的日志內(nèi)容。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS取request值以及自動(dòng)執(zhí)行使用示例
在網(wǎng)頁中JS函數(shù)自動(dòng)執(zhí)行常用三種方法,下面為大家詳細(xì)介紹下JS取request值以及自動(dòng)執(zhí)行使用,需要的朋友可以參考下2014-02-02
webpack學(xué)習(xí)筆記之代碼分割和按需加載的實(shí)例詳解
本篇文章主要介紹了webpack學(xué)習(xí)筆記之代碼分割和按需加載的實(shí)例詳解,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07
整理關(guān)于Bootstrap導(dǎo)航的慕課筆記
這篇文章主要為大家整理了關(guān)于Bootstrap導(dǎo)航的慕課筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()
這篇文章主要介紹了JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()的相關(guān)資料,需要的朋友可以參考下2016-08-08
JS實(shí)現(xiàn)簡(jiǎn)易的圖片拖拽排序?qū)嵗a
這篇文章主要介紹了JS實(shí)現(xiàn)簡(jiǎn)易的圖片拖拽排序?qū)嵗a,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06
詳解bootstrap導(dǎo)航欄.nav與.navbar區(qū)別
本篇文章主要介紹了詳解bootstrap導(dǎo)航欄.nav與.navbar區(qū)別,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11
JavaScript實(shí)現(xiàn)全選和全不選操作
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)全選和全不選操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
微信小程序如何實(shí)現(xiàn)radio單選框單擊打勾和取消

