zoukankan      html  css  js  c++  java
  • [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文件

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

    学习来源

    http://www.runoob.com/nodejs/nodejs-process.html

  • 相关阅读:
    7.21
    7.14
    7.7
    大学生失物招领平台使用体验及改进意见
    cdh集群迁移 ip更改
    klearn.preprocessing.PolynomialFeatures学习
    二元线性回归
    python学习之numpy.ewaxis
    sklearn.linear_model.LinearRegresion学习
    一元线性回归-梯度下降法-房价预测
  • 原文地址:https://www.cnblogs.com/wolf-sun/p/6890677.html
Copyright © 2011-2022 走看看