NodeJS多进程

Node以单线程的方式运行,通过事件驱动的方式来减少开销车,处理并发。我们可以注册多进程,然后监听子进程的事件来实现并发

简介

Node提供了child_process模块来处理子进程,有三种形式

  • exec:直接在terminal里面开启进程
  • spawn:指定命令+参数
  • fork:与spawn类似,默认node执行,并且父子间建立通信管道,可以实现进程间通信

exec

slave.js

var f = function(){
// process全局可以获得当前进程的信息
console.log("进程", process.argv[2] + "执行结束")
}
// 延迟运行,现node的注册机制和并发
setTimeout(f, 1000*(3-process.argv[2]));

master.js

const child_process = require('child_process')

for (var id = 0; id<3; id++){
// 开启子进程,并处理输出
var subProcess = child_process.exec('node slave.js '+id,function (error, stdout, stderr) {
if (error){
console.error(error)
}
else{
console.log('stdout: '+stdout)
console.log('stderr: '+stderr)
}
})
// 监听三个进程
subProcess.on('exit',function (code) {
console.log("子进程已经退出 "+code) //打印退出码
})
}
子进程已经退出 0
stdout: 进程 2执行 stderr:
子进程已经退出 0
stdout: 进程 1执行 stderr:
子进程已经退出 0
stdout: 进程 0执行 stderr:

spawn

const child_process = require('child_process')

for (var id = 0; id<3; id++){
// 开启子进程,并处理输出,这种传参方式更加规整一些
var subProcess = child_process.spawn('node', ['slave.js', id])
// 监听流
subProcess.stdout.on('data',function (data) {
console.log('stdout: '+data)
}) subProcess.stderr.on('data',function (data) {
console.log('stderr: '+data)
}) // 监听三个进程
subProcess.on('exit',function (code) {
console.log("子进程已经退出 "+code) //打印退出码
})
}

运算结果与exec版本一致

fork

const child_process = require('child_process')

for (var id = 0; id<3; id++){
// 开启子进程,并处理输出
var subProcess = child_process.fork('slave.js', [id])
// 监听三个进程
subProcess.on('exit',function (code) {
console.log("子进程已经退出 "+code) //打印退出码
})
}

运算结果

进程 2执行结束
子进程已经退出 0
进程 1执行结束
子进程已经退出 0
进程 0执行结束
子进程已经退出 0

值得注意的是,fork的子进程输出内容输出在父进程的同一个terminal中

NodeJS多进程的更多相关文章

  1. nodeJs多进程Cluster

    在前端页面中,如果我们想进行多进程,我们会用到WebWorker,而在NodeJs中,我们如果想充分利用服务器核心资源,我们会用到Node中Cluster模块 直接上代码吧: const cluste ...

  2. 浅谈NodeJS多进程服务架构基本原理

    阅读目录 一:nodejs进程进化及多进程架构原理 二:node中child_process模块实现多进程 三:父子进程间如何通信? 四:理解cluster集群 回到顶部 一:nodejs进程进化及多 ...

  3. NodeJs多进程和socket.io通讯-DEMO

    一.开启多进程 const os = require('os'); const cp = require('child_process'); const forkList = {}; const fo ...

  4. nodejs review-03

    39 Serve different file types with our server 处理文件类型 function content_type(filename) { var ext = pat ...

  5. nodejs(二) --- 重要知识点回顾

    1. 运行一个nodejs文件, 如一个js文件中只含有console.log("hello world");的文件,我们再git里运行node,即 node hello.js 即 ...

  6. node.js WebService异常处理(domain)以及利用domain实现request生命周期的全局变量

    成熟的Web Service技术,例如Fast CGI.J2EE.php,必然会对代码异常有足够的保护,好的Web必然会在出错后给出友好的提示,而不是莫名其妙的等待504超时.而node.js这里比较 ...

  7. 自建简易FaaS平台

    近些年来,传统的 IaaS.PaaS 已经无法满足人们对资源调度的需求了.各大云厂商相继开始推出自家的 Serverless 服务.Serverless 顾名思义,它是"无服务器" ...

  8. 关于Nodejs的多进程模块Cluster

    关于Nodejs的多进程模块Cluster   前述 我们都知道nodejs最大的特点就是单进程.无阻塞运行,并且是异步事件驱动的.Nodejs的这些特性能够很好的解决一些问题,例如在服务器开发中,并 ...

  9. Nodejs中cluster模块的多进程共享数据问题

    Nodejs中cluster模块的多进程共享数据问题 前述 nodejs在v0.6.x之后增加了一个模块cluster用于实现多进程,利用child_process模块来创建和管理进程,增加程序在多核 ...

随机推荐

  1. MyBatis - 4.动态SQL

    动态 SQL是MyBatis强大特性之一.极大的简化我们拼装SQL的操作. 动态 SQL 元素和使用 JSTL 或其他类似基于 XML 的文本处理器相似. MyBatis 采用功能强大的基于 OGNL ...

  2. Java基础知识➣多线程编程(五)

    概述 Java 给多线程编程提供了内置的支持.一个多线程程序包含两个或多个能并发运行的部分.程序的每一部分都称作一个线程,并且每个线程定义了一个独立的执行路径.使用多线程也是为了充分的利用服务器资源, ...

  3. codeforces 1037

    题解: E-trips 哎哎哎好傻逼啊 没有想到算不能的一直在想怎么算能的 太傻逼了 其实很简单 我们只需要对好友<=k的首先dfs一下给他连接着的朋友-1 然后如果小于了就递归下去 这个正确性 ...

  4. Centos安装Samba共享服务器

    安装Samba 查看Samba是否已安装 1.# rpm -qa | grep samba

  5. form表单总结

    form表单是一个基础的表单控件,最近做扫码登陆使用到,在这里记录一下 <form action="url" method="get" target=&q ...

  6. phpmyadmin详细的图文使用教程

    做网站用到服务器有很多站长应该都会用到数据库,那么phpmyadmin的使用也会是很多新手站长头大的问题,下面小编详细介绍一下phpmyadmin详细的图文使用教程. 方法/步骤     如何进入ph ...

  7. 关系网络数据可视化:3. 案例:公司职员关系图表 & 导演演员关系网络可视化

    1. 公司职员关系图表 节点和边界数据 节点是指每个节点本身的数据,代表公司职工的名称:属性(Country).分类(Category)和地区(Region,给每个节点定义的属性数据).文件必须是.c ...

  8. HBase API操作

    |的ascII最大ctrl+shift+t查找类  ctrl+p显示提示 HBase API操作 依赖的jar包 <dependencies> <dependency> < ...

  9. Java实现Windows、Mouse监听器

    1.通过实现WindowListener接口来实现Windows监听器: import java.awt.event.WindowEvent; import java.awt.event.Window ...

  10. TF之RNN:matplotlib动态演示之基于顺序的RNN回归案例实现高效学习逐步逼近余弦曲线—Jason niu

    import tensorflow as tf import numpy as np import matplotlib.pyplot as plt BATCH_START = 0 TIME_STEP ...