将stdout重定向到文件node.js

编程入门 行业动态 更新时间:2024-10-27 04:36:21
本文介绍了将stdout重定向到文件node.js的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我创建了:

var access = fs.createWriteStream('/var/log/node/api.access.log', { flags: 'w' });

然后通过管道传输:

process.stdout.pipe(access);

然后尝试:

console.log("test");

/var/log/node/api.access.log中没有任何内容.但是这种方式有效:

And nothing has appeared in /var/log/node/api.access.log. However this way is working:

process.stdout.pipe(access).write('test');

有人可以解释我在做什么错吗?

Could someone explain what am I doing wrong ?

推荐答案

我通过以下方式解决了这个问题:

I solved this problem the following way:

var access = fs.createWriteStream('/var/log/node/api.access.log'); process.stdout.write = process.stderr.write = access.write.bind(access);

当然,如果需要,您也可以将stdout和stderr分开.

Of course you can also separate stdout and stderr if you want.

我也强烈建议处理未捕获的异常:

I also would strongly recommend to handle uncaught exceptions:

process.on('uncaughtException', function(err) { console.error((err && err.stack) ? err.stack : err); });

这将涵盖以下情况:

  • process.stdout.write
  • process.stderr.write
  • console.log
  • console.dir
  • console.error
  • someStream.pipe(process.stdout);
  • 抛出新的错误(崩溃");
  • 抛出从不这样做";
  • 未定义;

更多推荐

将stdout重定向到文件node.js

本文发布于:2023-10-09 10:37:10,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1475507.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:重定向   文件   stdout   node   js

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!