日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。