日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

自己动手写一个nodejs的日志生成器

發布時間:2025/4/16 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 自己动手写一个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的日志生成器的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。