這篇文章主要講解了“Node.js+Winston庫怎么構建簡單日志功能”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Node.js+Winston庫怎么構建簡單日志功能”吧!
創(chuàng)新互聯(lián)建站服務項目包括分宜網站建設、分宜網站制作、分宜網頁制作以及分宜網絡營銷策劃等。多年來,我們專注于互聯(lián)網行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網行業(yè)的解決方案,分宜網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到分宜省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!
Winston 是強大、靈活的 Node.js
開源日志庫之一,理論上, Winston 是一個可以記錄所有信息的記錄器。這是一個高度直觀的工具,易于定制??梢酝ㄟ^更改幾行代碼來調整其背后的邏輯。它使對數(shù)據(jù)庫或文件等持久存儲位置的日志記錄變得簡單容易?!就扑]學習:《nodejs 教程》】
Winston 提供以下功能:
集中控制日志記錄的方式和時間:在一個地方更改代碼即可
控制日志發(fā)送的位置:將日志同步保存到多個目的地(如Elasticsearch、MongoDB、Postgres等)。
自定義日志格式:帶有時間戳、顏色日志級別、JSON格式等前綴。
實踐代碼將在項目 pretender-service 中增加日志功能,安裝依賴:
npm install winston --save
接下來需要初始化 logger
,由于項目中已經存在一個 logger.js
文件,這里再創(chuàng)建一個 winstonLogger.js
,代碼如下:
const { createLogger, format, transports } = require("winston"); module.exports = createLogger({ transports: [ new transports.File({ filename: "logs/server.log", level: "info", format: format.combine( format.timestamp({ format: "MMM-DD-YYYY HH:mm:ss" }), format.align(), format.printf( (info) => `${info.level}: ${[info.timestamp]}: ${info.message}` ) ), }), ], });
通過調用 winston
庫中的 createLogger
函數(shù)來初始化記錄器。在 transports
對象中,可以提供一個文件名將日志存儲在文件中。默認情況下,日志記錄未格式化并打印為帶有兩個參數(shù)的 JSON 字符串,日志消息和等級。
下面對之前的 logger
進行修改,將winston
日志記錄器加入進去,具體修改方式參閱代碼,下面給出其使用方法:
const winlogger = require("./winstonLogger"); winlogger.info("日志內容");
執(zhí)行程序后可以會在根目錄生成相應的日志文件 logs/server.log
也可以更改日志級別,修改 logger
,只在 console.error
方式下使用 winston
:
記錄了數(shù)據(jù)庫連接錯誤信息,上面的信息僅只是為了演示。
winston
允許設置多種 transport
,在 winstonLogger.js
中更改 createLogger
函數(shù)如下:
const { createLogger, format, transports } = require("winston"); module.exports = createLogger({ format: format.combine( format.timestamp({ format: "MMM-DD-YYYY HH:mm:ss" }), format.align(), format.printf((i) => `${i.level}: ${[i.timestamp]}: ${i.message}`) ), transports: [ new transports.File({ filename: "logs/info.log", level: "info", format: format.combine( format.printf((i) => i.level === "info" ? `${i.level}: ${i.timestamp} ${i.message}` : "" ) ), }), new transports.File({ filename: "logs/error.log", level: "error", }), ], });
再次執(zhí)行程序,將會看到 error.log
和 info.log
文件,由于在 logger
中未設置 info
,因此 info.log
的內容為空,error.log
內容和上面的一樣。
winston
允許設置多個 logger
,在實際項目中可以為每個模塊創(chuàng)建一個記錄器 logger
, 如下代碼,創(chuàng)建一個用戶日志記錄器和登錄驗證記錄器:
const { createLogger, format, transports } = require("winston"); const customFormat = format.combine( format.timestamp({ format: "MMM-DD-YYYY HH:mm:ss" }), format.align(), format.printf((i) => `${i.level}: ${[i.timestamp]}: ${i.message}`) ); const globalLogger = createLogger({ format: customFormat, transports: [ new transports.File({ filename: "logs/info.log", level: "info", format: format.combine( format.printf((i) => i.level === "info" ? `${i.level}: ${i.timestamp} ${i.message}` : "" ) ), }), new transports.File({ filename: "logs/error.log", level: "error", }), ], }); const authLogger = createLogger({ transports: [ new transports.File({ filename: "logs/authLog.log", format: customFormat, }), ], }); module.exports = { globalLogger: globalLogger, authLogger: authLogger, };
修改后代碼創(chuàng)建了一個全局記錄器 globalLogger
和一個鑒權記錄器 authLogger
,對應修改 logger.js
:
const { globalLogger } = require("./winstonLogger"); globalLogger.error(message);
正如前面介紹的最佳實踐中提到的,按照特定的條件對日志文件進行分割,通常按照日期、大小進行分割,并設置保存的日志天數(shù)。為實現(xiàn)這些需求,要有一個安裝一個 Winston 相關的依賴庫。
npm install winston-daily-rotate-file --save
安裝完成后使用以下代碼更新到 winstonLogger.js
文件:
const { createLogger, format, transports } = require("winston"); require("winston-daily-rotate-file"); const customFormat = format.combine( format.timestamp({ format: "MMM-DD-YYYY HH:mm:ss" }), format.align(), format.printf((i) => `${i.level}: ${[i.timestamp]}: ${i.message}`) ); const defaultOptions = { format: customFormat, datePattern: "YYYY-MM-DD", zippedArchive: true, maxSize: "20m", maxFiles: "14d", }; const globalLogger = createLogger({ format: customFormat, transports: [ new transports.DailyRotateFile({ filename: "logs/info-%DATE%.log", level: "info", ...defaultOptions, }), new transports.DailyRotateFile({ filename: "logs/error-%DATE%.log", level: "error", ...defaultOptions, }), ], }); const authLogger = createLogger({ transports: [ new transports.DailyRotateFile({ filename: "logs/authLog-%DATE%.log", ...defaultOptions, }), ], }); module.exports = { globalLogger: globalLogger, authLogger: authLogger, };
運行項目,可以看到日志文件:
感謝各位的閱讀,以上就是“Node.js+Winston庫怎么構建簡單日志功能”的內容了,經過本文的學習后,相信大家對Node.js+Winston庫怎么構建簡單日志功能這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!