Node.js中child_process实现多进程


Posted in Javascript onFebruary 03, 2015
var http = require('http');

function fib (n) {

    if (n < 2) {

        return 1;

    } else {

        return fib(n - 2) + fib(n - 1);

    }

}

var server = http.createServer(function (req, res) {

    var num = parseInt(req.url.substring(1), 10);

    res.writeHead(200);

    res.end(fib(num) + "\n");

});

server.listen(8000);

以上示例提供了一个斐波纳契数列的计算服务,由于此计算相当耗时,且是单线程,当同时有多个请求时只能处理一个,通过child_process.fork()就可以解决此问题

这里引用一下官网上的一个示例,通过这个例子可以很好的理解fork()的功能

var cp = require('child_process');

var n = cp.fork(__dirname + '/sub.js');

n.on('message', function(m) {

  console.log('PARENT got message:', m);

});

n.send({ hello: 'world' });

执行上述代码片段的运行结果:

PARENT got message: { foo: 'bar' }

CHILD got message: { hello: 'world' }

sub.js的内容如下:

process.on('message', function(m) {

  console.log('CHILD got message:', m);

});

process.send({ foo: 'bar' });

在子进程中process对象有send()方法,同时它在每一次接收到消息时都会发布消息对象

有点晕的是:child.send()发送的消息,是由process.on()方法接收的,process.send()方法发送的消息是由child.on()方法接收的

参照这个例子我们就可以把第一个提供斐波纳契数据的服务进行改进,使每一个请求都有单独的一个新的进程来处理

var http = require('http');

var cp = require('child_process');

var server = http.createServer(function(req, res) {

    var child = cp.fork(__dirname + '/fibonacci-calc.js');//每个请求都单独生成一个新的子进程

    child.on('message', function(m) {

        res.end(m.result + '\n');

    });

    var input = parseInt(req.url.substring(1));

    child.send({input : input});

});

server.listen(8000);

fibonacci-calc.js

function fib(n) {

    if (n < 2) {

        return 1;

    } else {

        return fib(n - 2) + fib(n - 1);

    }

}

process.on('message', function(m) {

    process.send({result: fib(m.input)});

});

启动服务后,访问http://localhost:8080/9就可以计算出9的斐波纳契数列的值

以上就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JavaScript使用prototype定义对象类型(转)[
Dec 22 Javascript
jquery 多级下拉菜单核心代码
May 21 Javascript
jQuery对象[0]是什么含义?
Jul 31 Javascript
Asp.net下使用Jquery Ajax传送和接收DataTable的代码
Sep 12 Javascript
基于jquery实现的上传图片及图片大小验证、图片预览效果代码
Apr 12 Javascript
jQuery实现输入框邮箱内容自动补全与上下翻动显示效果【附demo源码下载】
Sep 20 Javascript
js style.display=block显示布局错乱问题的解决方法
Sep 21 Javascript
angular 动态组件类型详解(四种组件类型)
Feb 22 Javascript
js实现一个简单的数字时钟效果
Mar 29 Javascript
如何使用JS在HTML中自定义字符串格式化
Jul 20 Javascript
详解js常用分割取字符串的方法
May 15 Javascript
vue-froala-wysiwyg 富文本编辑器功能
Sep 19 Javascript
jquery实现增加删除行的方法
Feb 03 #Javascript
自定义函数实现IE7与IE8不兼容js中trim函数的问题
Feb 03 #Javascript
director.js实现前端路由使用实例
Feb 03 #Javascript
js与jquery回车提交的方法
Feb 03 #Javascript
JS实现至少包含字母、大小写数字、字符的密码等级的两种方法
Feb 03 #Javascript
Javascript中call和apply函数的比较和使用实例
Feb 03 #Javascript
基于javascript、ajax、memcache和PHP实现的简易在线聊天室
Feb 03 #Javascript
You might like
神族 Protoss 历史背景
2020/03/14 星际争霸
php中的实现trim函数代码
2007/03/19 PHP
smarty半小时快速上手入门教程
2014/10/27 PHP
yii2带搜索功能的下拉框实例详解
2016/05/12 PHP
jQuery代码优化之基本事件
2011/11/01 Javascript
学习使用bootstrap基本控件(table、form、button)
2016/04/12 Javascript
javascript 内置对象及常见API详细介绍
2016/11/01 Javascript
Angular.js实现多个checkbox只能选择一个的方法示例
2017/02/24 Javascript
Angular.js中$resource高大上的数据交互详解
2017/07/30 Javascript
JS继承与闭包及JS实现继承的三种方式
2017/10/15 Javascript
windows实现npm和cnpm安装步骤
2019/10/24 Javascript
vue学习之Vue-Router用法实例分析
2020/01/06 Javascript
[01:21:36]CHAOS vs Alliacne 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
浅析python 中__name__ = '__main__' 的作用
2014/07/05 Python
Python实现从订阅源下载图片的方法
2015/03/11 Python
Flask入门教程实例:搭建一个静态博客
2015/03/27 Python
Python之csv文件从MySQL数据库导入导出的方法
2018/06/21 Python
详解Python3序列赋值、序列解包
2019/05/14 Python
使用Python求解带约束的最优化问题详解
2020/02/11 Python
Keras设定GPU使用内存大小方式(Tensorflow backend)
2020/05/22 Python
详解python中的lambda与sorted函数
2020/09/04 Python
Python通过yagmail实现发送邮件代码解析
2020/10/27 Python
Python WebSocket长连接心跳与短连接的示例
2020/11/24 Python
Html5 APP中监听返回事件处理的方法示例
2018/03/15 HTML / CSS
乌克兰移动电子产品和相关配件的在线商店:iTMag
2020/03/16 全球购物
如何利用find命令查找文件
2015/02/07 面试题
应届生船舶驾驶求职信
2013/10/19 职场文书
幼儿园美术教学反思
2014/01/31 职场文书
学习雷锋倡议书
2014/04/15 职场文书
教师职位说明书
2014/07/29 职场文书
企业领导班子四风对照检查材料
2014/09/27 职场文书
车辆委托书范本
2014/10/05 职场文书
人事行政助理岗位职责
2015/04/11 职场文书
CSS3实现的3D隧道效果
2021/04/27 HTML / CSS
浏览器常用基本操作之python3+selenium4自动化测试(基础篇3)
2021/05/21 Python
在SQL Server中使用 Try Catch 处理异常的示例详解
2022/07/15 SQL Server