Node.js中child_process實(shí)現(xiàn)多進(jìn)程
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);
以上示例提供了一個(gè)斐波納契數(shù)列的計(jì)算服務(wù),由于此計(jì)算相當(dāng)耗時(shí),且是單線程,當(dāng)同時(shí)有多個(gè)請求時(shí)只能處理一個(gè),通過child_process.fork()就可以解決此問題
這里引用一下官網(wǎng)上的一個(gè)示例,通過這個(gè)例子可以很好的理解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' });
執(zhí)行上述代碼片段的運(yùn)行結(jié)果:
PARENT got message: { foo: 'bar' }
CHILD got message: { hello: 'world' }
sub.js的內(nèi)容如下:
process.on('message', function(m) {
console.log('CHILD got message:', m);
});
process.send({ foo: 'bar' });
在子進(jìn)程中process對象有send()方法,同時(shí)它在每一次接收到消息時(shí)都會發(fā)布消息對象
有點(diǎn)暈的是:child.send()發(fā)送的消息,是由process.on()方法接收的,process.send()方法發(fā)送的消息是由child.on()方法接收的
參照這個(gè)例子我們就可以把第一個(gè)提供斐波納契數(shù)據(jù)的服務(wù)進(jìn)行改進(jìn),使每一個(gè)請求都有單獨(dú)的一個(gè)新的進(jìn)程來處理
var http = require('http');
var cp = require('child_process');
var server = http.createServer(function(req, res) {
var child = cp.fork(__dirname + '/fibonacci-calc.js');//每個(gè)請求都單獨(dú)生成一個(gè)新的子進(jìn)程
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)});
});
啟動服務(wù)后,訪問http://localhost:8080/9就可以計(jì)算出9的斐波納契數(shù)列的值
以上就是本文的全部內(nèi)容了,希望大家能夠喜歡。
相關(guān)文章
HTTP JSON接口模擬工具Interfake快速入門教程
這篇文章主要為大家介紹了HTTP JSON接口模擬工具Interfake快速入門教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06Bun入門學(xué)習(xí)教程吊打Node或Deno的現(xiàn)代JS運(yùn)行時(shí)
這篇文章主要為大家介紹了一款吊打Node或Deno的現(xiàn)代JS運(yùn)行時(shí),Bun入門學(xué)習(xí)教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Node.js實(shí)現(xiàn)分片上傳斷點(diǎn)續(xù)傳示例詳解
這篇文章主要為大家介紹了Node.js實(shí)現(xiàn)分片上傳斷點(diǎn)續(xù)傳示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07基于node搭建服務(wù)器,寫接口,調(diào)接口,跨域的實(shí)例
今天小編就為大家分享一篇基于node搭建服務(wù)器,寫接口,調(diào)接口,跨域的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05從零學(xué)習(xí)node.js之模塊規(guī)范(一)
Node.js是一個(gè)基于谷歌瀏覽器JavaScript執(zhí)行環(huán)境建立的一個(gè)平臺,讓JavaScript可以脫離客戶端瀏覽器運(yùn)行,讓 JavaScript具有服務(wù)器語言的能力。從本文開始我們進(jìn)行學(xué)習(xí)node.js,這篇文章主要介紹的是node.js中模塊規(guī)范的相關(guān)資料,需要的朋友可以參考下。2017-02-02Node.js中MongoDB查詢數(shù)據(jù)的方法
在Node.js中,可以使用MongoDB驅(qū)動程序和Mongoose庫來進(jìn)行MongoDB的查詢操作,本文就來介紹一下Node.js中MongoDB查詢數(shù)據(jù)的方法,感興趣的可以了解一下2023-12-12