手记

[Node.js]多进程

摘要

Node.js是以单线程的模式运行的,但它使用的是事件驱动来处理并发,这样有助于在多核cpu的系统上创建多个子进程,从而提高性能。每个子进程总是带有三个流对象:child.stdin,child.stdout,child.stderr。他们可能会共享父进程的stdio流,或者也可以是独立的被导流的流对象。

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

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

  • spawn-child_process.spawn使用指定的命令行参数创建新进程。

  • fork-child_process.fork是spawn()的特殊形式,用于在子进程中运行的模块,如fork("./son.js")相当于spawn("node",["./son.js"])。与spawn方法不同的是,fork会在父进程与子进程之间,建立一个通信管道,用于进程之间的通信。

exec方法

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

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

参数

command:字符串,将要运行的命令,参数使用空格隔开。

options:对象,可以是:

  • cwd:字符串,子进程的当前工作目录。

  • env:对象环境变量键值对。

  • encoding:字符串,字符编码,默认utf8

  • shell,字符串,将要执行命令的shell(默认,在unix中为/bin/sh,在windows中cmd.exe,shell应当能识别-c开关在unix中,或/s /c在windows中。在windows中,命令行解析应当能兼容cmd.exe)

  • timeout:数字,超时时间,默认0.

  • maxBuffer:数字,在stdout或stderr中允许存在的最大缓冲(二进制),如果超出那么子进程将会被杀死(默认 200*1024)

  • killSignal:字符串,结束信号(默认:‘SIGTERM’)

  • uid:数字,设置用户进程的ID

  • gid:数字,设置进程组的Id

  • callback:回调函数,包含三个参数error,stdout和stderr。

exec()方法返回最大的缓冲区,并等待进程结束,一次性返回缓冲区的内容。

一个例子

创建两个js文件support.js和master.js

support.js

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

master.js

spawn()方法

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

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

command: 将要运行的命令

args: Array 字符串参数数组

options Object

  • cwd String 子进程的当前工作目录

  • env Object 环境变量键值对

  • stdio Array|String 子进程的 stdio 配置

  • detached Boolean 这个子进程将会变成进程组的领导

  • uid Number 设置用户进程的 ID

  • gid Number 设置进程组的 ID

spawn() 方法返回流 (stdout & stderr),在进程返回大量数据时使用。进程一旦开始执行时 spawn() 就开始接收响应。

一个例子

这里我们采用上面的例子,对master.js进行改造,如下:

 

fork方法

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

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

modulePath: String,将要在子进程中运行的模块

args: Array 字符串参数数组

options:Object

  • cwd String 子进程的当前工作目录

  • env Object 环境变量键值对

  • execPath String 创建子进程的可执行文件

  • execArgv Array 子进程的可执行文件的字符串参数数组(默认: process.execArgv)

  • silent Boolean 如果为true,子进程的stdinstdoutstderr将会被关联至父进程,否则,它们将会从父进程中继承。(默认为:false

  • uid Number 设置用户进程的 ID

  • gid Number 设置进程组的 ID

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

一个例子

改造master.js文件

这里出现错误,不知为啥?记录一下,等待之后查询资料解决。

0人推荐
随时随地看视频
慕课网APP