• node.js(七) 子进程 child_process模块


    众所周知node.js是基于单线程模型架构,这样的设计可以带来高效的CPU利用率,但是无法却利用多个核心的CPU,为了解决这个问题,node.js提供了child_process模块,通过多进程来实现对多核CPU的利用. child_process模块提供了四个创建子进程的函数,分别是spawn,exec,execFile和fork。

    1.spawn函数的简单用法

    spawn函数用给定的命令发布一个子进程,只能运行指定的程序,参数需要在列表中给出。如下示例:

    1. var child_process = require('child_process');
    2. var child = child_process.spawn( command );
    3. child.stdout.on('data', function(data) {
    4. console.log(data);
    5. });

    通过执行命令得到返回结果,我们就可以拿到标准输出流数据了。

    2.exec函数的简单用法

    exec也是一个创建子进程的函数,与spawn函数不同它可以直接接受一个回调函数作为参数,回调函数有三个参数,分别是err, stdout , stderr,基本使用方法如下:

    1. var child_process = require('child_process');
    2. child_process.exec( command , function(err, stdout , stderr ) {
    3. console.log( stdout );
    4. });

    exec函数可以直接接受一个回调函数作为参数,回调函数有三个参数,分别是err, stdout,stderr,非常方便直接使用,

    3.execFile函数的简单用法

    execFile函数与exec函数类似,但execFile函数更显得精简,因为它可以直接执行所指定的文件,基本使用方法如下:

    1. var child_process = require('child_process');
    2. child_process.execFile( file , function(err, stdout , stderr ) {
    3. console.log( stdout );
    4. });

    execFile与spawn的参数相似,也需要分别指定执行的命令和参数,但可以接受一个回调函数,与exec的回调函数相同。

    4.fork函数的简单用法

    fork函数可直接运行Node.js模块,所以我们可以直接通过指定模块路径而直接进行操作。使用方法如下:

    1. var child_process = require('child_process');
    2. child_process.fork( modulePath );

    该方法是spawn()的特殊情景,用于派生Node进程。除了普通ChildProcess实例所具有的所有方法,所返回的对象还具有内建的通讯通道。

  • 相关阅读:
    Java9模块化(Jigsaw)初识
    Java9 modules (Jigsaw)模块化迁移
    Java数据库连接——JDBC调用存储过程,事务管理和高级应用
    面向对象编程(三)——程序执行过程中内存分析
    面向对象编程(十)——继承之Super关键字及内存分析
    面向对象编程(十二)——final关键字
    项目管理利器——Maven阅读目录
    深入分析Java的序列化与反序列化
    Java提高篇——Java 异常处理
    怎么运行Typescript
  • 原文地址:https://www.cnblogs.com/qiuzhimutou/p/4758898.html
Copyright © 2020-2023  润新知