Node创建子线程监听文件修改

坑啊

node新手看《node.js开发实战》,刚开始照着书本打,就出现了坑!真是气人

'use strict'
const fs = require('fs')
const spawn = require('child_process').spawn
const filename = process.argv[2]//arguments vector的简写,它的值是数组,看下面打印了什么
if(!filename){
    throw Error('A file to watch must be specified ')
}
fs.watch(filename,()=>{
    const ls = spawn('ls',['-l','-h',filename])
    console.log(ls)
    console.log(ls.stdout) 
    ls.stdout.pipe(process.stdout)
})
console.log(`now watching File ${filename} for changes... `)

报错了!咋回事,我也看不懂

18774841-684f4e4c87712fd1.png
图片.png

于是去仔仔细细研究 child-process。(一路跟着这个错误科普吧)
Node创建子线程方法

异步方式:spawn、exec、execFile、fork
同步方式:spawnSync、execSync、execFileSync

介绍spawn用法 (其他方式差不多也是这样的形式):
child_process.spawn(command[, args][, options])
command: 要执行的指令
args: 传递参数
options: 配置项

①spawn:不会生成shell,没有时间限制
②exec:此方法生成一个 shell 并在 shell 中执行 command,有时间限制
③execFile和exec差别:通常用于执行文件,而且并不会创建子shell环境,有时间限制
④fork方法是spawn方法的一个特例,fork用于执行js文件创建Node.js子进程。而且fork方式创建的子进程与父进程之间建立了IPC通信管道,因此子进程和父进程之间可以通过send的方式发送消息。

注意:fork方式创建的子进程与父进程是完全独立的,它拥有单独的内存,单独的V8实例,因此并不推荐创建很多的Node.js子进程

//fork子线程与父线程通信
//父线程
const { fork } = require('child_process');
const forked = fork('child.js');
forked.on('message', (msg) => {
 console.log('Message from child', msg);
});
forked.send({ hello: 'world' });

//子线程
process.on('message', (msg) => {
 console.log('Message from parent:', msg);
});
let counter = 0;
setInterval(() => {
 process.send({ counter: counter++ });
}, 1000);

好的,回归正题

在linux,macOS系统下,shell默认是true的,但是window下默认为false,这个时候出现这个报错,所以我们需要把配置手动开开
变成这样子

const ls = spawn('ls',['-l','-h',filename],{
        stdio:'inherit',
        shell:true
    })

运行一下,还是报错了


18774841-415a7ba2f09fe52a.png
图片.png

嗯?pipe是什么鬼??不是一种格式化的输出工具吗?
我们再去了解一下这个pipe(管道)
pipe实现了管道输出,可以实现边写文件边读文件的一个东西(要知道之前读写文件是不能同时的噢)
更多详情请自己百度吧

为什么pipe会报null呢?


18774841-c9752a954429635a.png
图片.png

这又提供了新的方向
这可能是stdout的问题

ls.stdout.pipe(process.stdout)

打印一下这个子线程:console.log(ls)

18774841-e0ca2cca92a89f7f.png
图片.png

怎么会为空呢??又找呀找资料。
最后真相了!!(文末第三个链接)
18774841-835c1fd9ea8a2dcf.png
图片.png

根据我还没过六级的水平,都能看出,他说spawn创建的子线程,无论option里面配置什么,stdout都是null!!!

所以最后建议还是用on监听
你说,这不是是个坑货!
笔者太生气了,所以文风也有点激动了

参考资料:

https://blog.csdn.net/u010144805/article/details/80224697
https://www.cnblogs.com/chyingp/p/node-learning-guide-child_process.html
https://www.e-learn.cn/content/wangluowenzhang/834759

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值