最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Node.js中child_process实现多进程

来源:懂视网 责编:小采 时间:2020-11-27 20:27:49
文档

Node.js中child_process实现多进程

Node.js中child_process实现多进程: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(2
推荐度:
导读Node.js中child_process实现多进程: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(2

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的斐波纳契数列的值

文档

Node.js中child_process实现多进程

Node.js中child_process实现多进程: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(2
推荐度:
标签: js 进程 多进程
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top