蝙蝠岛资源网 Design By www.hbtsch.com
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文件夹下查看对应的日志内容。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
log4.js,使用
蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com
暂无如何在项目中使用log4.js的方法步骤的评论...
更新日志
2025年10月22日
2025年10月22日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]