node.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > node.js > Node.js多进程的方法

Node.js多进程的方法与参数实例说明

作者:疯狂创作者

这篇文章主要介绍了Node.js多进程的方法与参数实例说明,Node.js 是以单线程的模式运行的,但它使用的是事件驱动来处理并发,这样有助于我们在多核 cpu 的系统上创建多个子进程,从而提高性能,需要的朋友可以参考下

前言

我们都知道 Node.js 是以单线程的模式运行的,但它使用的是事件驱动来处理并发,这样有助于我们在多核 cpu 的系统上创建多个子进程,从而提高性能。

每个子进程总是带有三个流对象:child.stdin, child.stdout 和child.stderr。他们可能会共享父进程的 stdio 流,或者也可以是独立的被导流的流对象。

Node 提供了 child_process 模块来创建子进程,方法有:

方法说明

exec() 方法

child_process.exec 使用子进程执行命令,缓存子进程的输出,并将子进程的输出以回调函数参数的形式返回。

语法如下所示:

child_process.exec(command[, options], callback)

参数

参数说明如下:

实例

让我们创建两个 js 文件 support.js 和 master.js。

support.js 文件代码:

console.log("进程 " + process.argv[2] + " 执行。" );

master.js 文件代码:

const fs = require('fs'); 
const child_process = require('child_process'); 
for(var i=0; i<3; i++) { 
    var workerProcess = child_process.exec('node support.js '+i, 
        function (error, stdout, stderr) {  
            if (error) { 
                console.log(error.stack); 
                console.log('Error code: '+error.code); 
                console.log('Signal received: '+error.signal); 
            } 
            console.log('stdout: ' + stdout); 
            console.log('stderr: ' + stderr); 
        }); 
        workerProcess.on('exit', 
            function (code) { 
                console.log('子进程已退出,退出码 '+code); 
            }); 
}

执行以上代码,输出结果为:

$ node master.js 
子进程已退出,退出码 0
stdout: 进程 1 执行。

stderr: 
子进程已退出,退出码 0
stdout: 进程 0 执行。

stderr: 
子进程已退出,退出码 0
stdout: 进程 2 执行。

stderr:

spawn() 方法

child_process.spawn 使用指定的命令行参数创建新进程,语法格式如下:

child_process.spawn(command[, args][, options])

参数

参数说明如下:

实例

让我们创建两个 js 文件 support.js 和 master.js。

support.js 文件代码:

console.log("进程 " + process.argv[2] + " 执行。" );

master.js 文件代码:

const fs = require('fs'); 
const child_process = require('child_process'); 
for(var i=0; i<3; i++) { 
    var workerProcess = child_process.spawn('node', ['support.js', i]); 
    workerProcess.stdout.on('data',
        function (data) { 
            console.log('stdout: ' + data); 
        }); 
        workerProcess.stderr.on('data', 
            function (data) { 
                console.log('stderr: ' + data); }); 
                workerProcess.on('close', 
                    function (code) { 
                        console.log('子进程已退出,退出码 '+code); 
                    }); 
}

执行以上代码,输出结果为:

$ node master.js stdout: 进程 0 执行。
子进程已退出,退出码 0
stdout: 进程 1 执行。
子进程已退出,退出码 0
stdout: 进程 2 执行。
子进程已退出,退出码 0

fork 方法

child_process.fork 是 spawn() 方法的特殊形式,用于创建进程,语法格式如下:

child_process.fork(modulePath[, args][, options])

参数

参数说明如下:

返回的对象除了拥有ChildProcess实例的所有方法,还有一个内建的通信信道。

实例

让我们创建两个 js 文件 support.js 和 master.js。

support.js 文件代码:

console.log("进程 " + process.argv[2] + " 执行。" );

master.js 文件代码:

const fs = require('fs'); 
const child_process = require('child_process'); 
for(var i=0; i<3; i++) { 
    var worker_process = child_process.fork("support.js", [i]); 
    worker_process.on('close', 
        function (code) { 
            console.log('子进程已退出,退出码 ' + code); 
        }); 
}

执行以上代码,输出结果为:

$ node master.js 
进程 0 执行。
子进程已退出,退出码 0
进程 1 执行。
子进程已退出,退出码 0
进程 2 执行。
子进程已退出,退出码 0

到此这篇关于Node.js多进程的方法与参数实例说明的文章就介绍到这了,更多相关Node.js多进程的方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文