微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在node.js中执行`tail -f logfile.txt`类似的处理?

tail -f logfile.txt输出logfile.txt的最后10行,然后随着文件增长继续输出附加的数据。

在node.js中执行-f部分的推荐方法是什么?

以下输出整个文件(忽略“显示最后10行”),然后退出

var fs = require('fs');
var rs = fs.createReadStream('logfile.txt',{ flags: 'r',encoding: 'utf8'});
rs.on('data',function(data) {
  console.log(data);
});

我知道事件循环正在退出,因为在流结束&关闭事件没有更多的事件 – 我很好奇继续监视流的最佳方式。

解决方法

这样做的规范方法fs.watchFile

或者,你可以使用the node-tail module,它在内部使用fs.watchFile,并且已经为你完成了工作。这里是一个使用它直接从文档的例子:

Tail = require('tail').Tail;

tail = new Tail("filetoTail");

tail.on("line",function(data) {
  console.log(data);
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐