[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
,子进程的stdin
,stdout
和stderr
将会被关联至父进程,否则,它们将会从父进程中继承。(默认为:false
) - uid Number 设置用户进程的 ID
- gid Number 设置进程组的 ID
返回的对象除了拥有ChildProcess实例的所有方法,还有一个内建的通信信道。
一个例子
改造master.js文件
这里出现错误,不知为啥?记录一下,等待之后查询资料解决。
学习来源
-
博客地址:http://www.cnblogs.com/wolf-sun/
博客版权:如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2015-05-22 Quartz.Net在windows服务中的使用