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