【Node.js实战】一文带你开发博客项目之日志(文件读写、stream流、写日志)
const fs = require('fs');
const path = require('path');
const util = require('util');
// 创建可写流
const logStream = fs.createWriteStream(path.join(__dirname, 'debug.log'), { flags: 'a' });
// 使用pipeline进行异步文件写入
const pipeline = util.promisify(stream.pipeline);
// 写入日志函数
async function writeLog(message) {
try {
// 将日志和时间戳写入日志文件
const logMessage = `${new Date().toISOString()}: ${message}\n`;
await pipeline(fs.createReadableStream(logMessage), logStream);
} catch (error) {
// 处理写入日志过程中的错误
console.error('写入日志时发生错误:', error);
}
}
// 示例:写入日志
writeLog('启动博客项目');
这段代码首先引入了必要的Node.js模块,并创建了一个日志文件的可写流。然后定义了一个异步函数writeLog
,它接受一条消息作为参数,并将其以时间戳的形式附加到日志文件中。使用stream.pipeline
确保文件写入操作是异步的,并且可能会捕获和处理错误。最后,给出了一个使用writeLog
函数的示例,展示了如何记录项目启动事件。
评论已关闭