溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用koa-log4管理nodeJs日志

發(fā)布時間:2021-07-20 10:45:26 來源:億速云 閱讀:116 作者:小新 欄目:web開發(fā)

小編給大家分享一下如何使用koa-log4管理nodeJs日志,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一.后端代碼目錄結構

├── back-end
│ ├── logs 所有產(chǎn)生的日志文件存放在此目錄下
│ ├── db.js 使用Sequelize連接數(shù)據(jù)庫
│ ├── logger.js 日志的配置
│ ├── server.js 后端提供的所有接口

二.引用日志模塊

log4js-node是一款比較好的在node環(huán)境下對于日志處理的模塊,由于我的整個項目是基于koa框架,所以我選擇了koa-log4模塊。

koa-log4在log4js-node的基礎上做了一次包裝,是koa的一個處理日志的中間件,此模塊可以幫助你按照你配置的規(guī)則分叉日志消息。

三.日志配置logger.js

koa-log4的配置與log4js-node是一樣的。

const path = require('path');
const log4js = require('koa-log4');

log4js.configure({
 appenders: {
  access: {
   type: 'dateFile',
   pattern: '-yyyy-MM-dd.log', //生成文件的規(guī)則
   filename: path.join('back-end/logs/', 'access.log') //生成文件名
  },
  application: {
   type: 'dateFile',
   pattern: '-yyyy-MM-dd.log',
   filename: path.join('back-end/logs/', 'application.log')
  },
  out: {
   type: 'console'
  }
 },
 categories: {
  default: { appenders: [ 'out' ], level: 'info' },
  access: { appenders: [ 'access' ], level: 'info' },
  application: { appenders: [ 'application' ], level: 'WARN'}
 }
});

exports.accessLogger = () => log4js.koaLogger(log4js.getLogger('access')); //記錄所有訪問級別的日志
exports.logger = log4js.getLogger('application'); //記錄所有應用級別的日志

四.日志的使用方法

1.訪問日志

對于日志的使用,訪問級別的,記錄用戶的所有請求,作為koa的中間件,直接使用便可,如下:

const Koa = require('koa');
const KoaRouter = require('koa-router');
const app = new Koa();
const router = new KoaRouter();
const { logger, accessLogger } = require('./logger');
const router = new KoaRouter();

app.use(accessLogger());

2.應用日志

應用級別的日志,可記錄全局狀態(tài)下的error,也可記錄接口請求當中的錯誤處理。

捕獲全局狀態(tài)下的error

app.on('error', err => {
 logger.error(err);
});

接口請求錯誤

router.post('/test',async (ctx, next)=>{
 //處理代碼
 }catch(e){
  logger.error(e);
  ctx.body = {status:-1, message:e.message};
 }
});

五.自動生成日志

開啟node應用對于每一次的請求,都將按日期來生成日志文件,以下是我這幾天自動生成的日志文件

如何使用koa-log4管理nodeJs日志

六.日志內(nèi)容分析

日志文件當中都有詳細的記錄

如何使用koa-log4管理nodeJs日志

以上是“如何使用koa-log4管理nodeJs日志”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI