NodeJs简明教程将从零开始学习NodeJs相关知识,助力JS开发者构建全栈开发技术栈!node
关注获取更多NodeJs精品文章
shell
本文是NodeJs简明教程的第八篇,将介绍NodeJs 子进程 模块相关的基本操做。数组
child_process 模块提供了衍生子进程的能力(以一种与 popen(3) 相似但不相同的方式)。微信
NodeJs的JS线程虽然是单线程,不能利用多核CPU,也不能执行CPU密集型的任务,可是经过派生子进程的形式加上IPC(进程间通讯),能够充分利用多核CPU。函数
spawn
能够执行指定的命令
,spawn
的函数原型以下:学习
child_process.spawn(command[,args][,options])
复制代码
<string>
要执行的命令<string[]>
传给命令的参数列表<Object>
额外选项
<string>
子进程workdir
<Object>
子进程环境变量const { spawn } = require('child_process');
const ls = spawn('ls', ['-lh', '/usr']); // 命令配置
ls.stdout.on('data', (data) => { // 监听命令执行的标准输出
console.log(`stdout: ${data}`);
});
ls.stderr.on('data', (data) => { // 监听命令执行的标准错误输出
console.log(`stderr: ${data}`);
});
ls.on('close', (code) => { // 监听子进程退出
console.log(`子进程退出,使用退出码 ${code}`);
});
复制代码
以上例程输出(不一样机器输出可能不同)ui
stdout: total 0
drwxr-xr-x 970 root wheel 30K 7 19 23:00 bin
drwxr-xr-x 306 root wheel 9.6K 7 12 22:35 lib
drwxr-xr-x 249 root wheel 7.8K 7 19 23:00 libexec
drwxr-xr-x 15 root wheel 480B 4 1 14:15 local
drwxr-xr-x 239 root wheel 7.5K 7 12 22:35 sbin
drwxr-xr-x 46 root wheel 1.4K 9 21 2018 share
drwxr-xr-x 5 root wheel 160B 9 21 2018 standalone
子进程退出,使用退出码 0
复制代码
exec
也能够执行指定的命令
,与spawn
区别是执行结果经过回调通知,spawn
是经过事件,exec
函数原型以下:spa
exec(command[,options][,callback])
复制代码
<string>
要执行的命令,命令参数使用空格分隔<Object>
额外选项
<string>
子进程workdir
<Object>
子进程环境变量<number>
子进程执行超时<Function>
执行结果回调
<Error>
执行错误(不是子进程的错误输出)<string|Buffer>
子进程标准输出<string|Buffer>
子进程标准错误输出const exec = require('child_process').exec;
exec('ls -lh /usr',function(err,stdout,stderr) {
if(err) {
console.log('执行错误', err);
}
console.log('stdout', stdout);
console.log('stderr', stderr);
});
复制代码
以上例程输出线程
stdout: total 0
drwxr-xr-x 970 root wheel 30K 7 19 23:00 bin
drwxr-xr-x 306 root wheel 9.6K 7 12 22:35 lib
drwxr-xr-x 249 root wheel 7.8K 7 19 23:00 libexec
drwxr-xr-x 15 root wheel 480B 4 1 14:15 local
drwxr-xr-x 239 root wheel 7.5K 7 12 22:35 sbin
drwxr-xr-x 46 root wheel 1.4K 9 21 2018 share
drwxr-xr-x 5 root wheel 160B 9 21 2018 standalone
子进程退出,使用退出码 0
复制代码
execFile
相似于exec
,但默认状况下不会派生shell, 相反,指定的可执行文件 file 会做为新进程直接地衍生,使其比 exec
稍微更高效。code
支持与exec
相同的选项。 因为没有衍生 shell,所以不支持 I/O 重定向和文件通配等行为
。execFile
原型:
execFile(file[,args][,options][,callback])
复制代码
<string>
要执行的命令或可执行文件路径<string[]>
字符串数组形式的参数列表<Object>
额外选项
<string>
子进程workdir
<Object>
子进程环境变量<number>
子进程执行超时<Function>
执行结果回调
<Error>
执行错误(不是子进程的错误输出)<string|Buffer>
子进程标准输出<string|Buffer>
子进程标准错误输出const execFile = require('child_process').execFile;
execFile('ls', ['--version'], function(error, stdout, stderr) {
if(err) {
console.log('执行错误', err);
}
console.log('stdout', stdout);
console.log('stderr', stderr);
});
复制代码
以上例程输出同exec
fork
是spawn
的一个特例,专门用于派生新的NodeJs进程
。spawn
能够派生任何进程
。fork
方法原型以下:
fork(modulePath[,args][,options])
复制代码
<string>
要执行的JS路径<string[]>
字符串数组形式的参数列表<Object>
额外选项
<string>
子进程的workdir
<Object>
环境变量<boolean>
若是为 true,则子进程的 stdin、stdout 和 stderr 将会被输送到父进程,不然它们将会继承自父进程。默认false
b.js
const fork = require('child_process').fork;
const child = fork('./a.js',{silent:true}); // silent为true时能够监听子进程标准输出和标准错误输出
child.stdout.on('data',function(data){ // 监听子进程标准输出
console.log('child stdout', data.toString('utf8'));
});
child.stderr.on('data', function(data){ // 监听子进程标准错误输出
console.log('child stderr', data.toString('utf8'));
});
child.on('close', function(){
console.log('child exit');
});
复制代码
a.js
console.log('我是子进程`);
复制代码
终端执行node b.js
,以上例程输出:
child stdout 我是子进程
child exit
复制代码
子进程模块的介绍到此就告一段落了,通常状况下使用spawn
和execFile
便可。有任何疑问请扫码加群交流: