博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Node.js]多进程
阅读量:7236 次
发布时间:2019-06-29

本文共 2061 字,大约阅读时间需要 6 分钟。

摘要

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文件

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

学习来源

转载地址:http://crofm.baihongyu.com/

你可能感兴趣的文章
SQL Server 2014 许可证(六)虚拟化中的授权
查看>>
老男孩之学好运维四要素“坚持”的启示
查看>>
疯狂ios讲义之网页控件(UIWebView)
查看>>
在配置完 Exchange Server 2010 CAS Array后需要做的两件事
查看>>
MongoDB管道聚合各阶段
查看>>
php-fpm chroot功能的使用
查看>>
记我在51CTO成长历程
查看>>
python 正则分析nginx日志
查看>>
【SeaJS】【2】再识SeaJS
查看>>
memcached 实验 (一) 安装调试
查看>>
nginx安装第三方模块file_md5
查看>>
SCCM 2007r2 操作系统播发故障处理案例一
查看>>
resin服务应用指南
查看>>
linux下rsync同步工具系列精品视频分享
查看>>
DWR操作java对象
查看>>
如何对大量exchange客户端的outlook进行快速配置
查看>>
演示:设置密码长度限制、密码加强
查看>>
微软私有云分享(R2)16PowerShell查看虚拟机信息
查看>>
zabbix服务器基础应用
查看>>
二级DPM 2010服务器备份失败(错误ID:3114)
查看>>