自己动手写一个nodejs的日志生成器
生活随笔
收集整理的這篇文章主要介紹了
自己动手写一个nodejs的日志生成器
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
自己動手寫一個nodejs的logger
最近正在邊學邊用node.js開發個人應用的server,由于有用到websocket相關,想對websocket的通信選擇性的做下日志記錄,所以萌發了自己動手寫一個logger的想法。
引用了node的fs模塊,還引入了moment類庫方便處理時間日期(moment需要自己安裝)。
個人感覺還有很多可以優化的地方,歡迎路過的同學提出寶貴意見!!!
下面直接貼代碼:
const fs = require('fs'); const moment = require('moment');// 上次寫入日志日期 年月日 let lastDate = moment().format('YYYY-MM-DD');// 創建日志文件 function createLogFile() {const year = moment().get('year'),month = moment().get('month') + 1,date = moment().get('date');const dirPath = './logs/' + year + '/' + month + '/';const fileName = date + '.log';const options = {flags: 'a', // encoding: 'utf8', // utf8編碼}// 創建日志目錄fs.mkdirSync(dirPath, { recursive: true });return fs.createWriteStream(dirPath + fileName, options); }// 生成日志寫入流 let writeStream = createLogFile();/*** 寫入日志* @param {*} chunk [寫入的日志內容]*/ const logger = function (chunk = '') {// 用于和上次寫入日志日期對比const nowDate = moment().format('YYYY-MM-DD');// 本條日志的寫入時間const dateTime = moment().format();// 將本次寫入時間和上次寫入日期對比,判斷是否為同一天if (nowDate === lastDate) {writeStream.write(dateTime + '\n' + chunk + '\n');lastDate = nowDate;} else {// 結束寫入流,結束完成后重新生成日志文件并寫入writeStream.end();writeStream.on('close', () => {writeStream = createLogFile();writeStream.write(dateTime + '\n' + chunk + '\n');});} }module.exports = logger;總結
以上是生活随笔為你收集整理的自己动手写一个nodejs的日志生成器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于chorme浏览器无法保存第三方co
- 下一篇: 网站新手引导/步骤引导