Node.js中child_process實作多進程_node.js
var http = require('http');
function fib (n) {
if (n 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 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的斐波納契數列的值
以上就是本文的全部內容了,希望大家能夠喜歡。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

基於無阻塞、事件驅動建立的Node服務,具有記憶體消耗低的優點,非常適合處理海量的網路請求。在海量請求的前提下,就需要考慮「記憶體控制」的相關問題了。 1. V8的垃圾回收機制與記憶體限制 Js由垃圾回收機

文件模組是對底層文件操作的封裝,例如文件讀寫/打開關閉/刪除添加等等文件模組最大的特點就是所有的方法都提供的**同步**和**異步**兩個版本,具有sync 字尾的方法都是同步方法,沒有的都是異

Golang作為一門高並發程式語言,其內建的協程機制和多執行緒操作實現了輕量級的多工處理。然而,在多進程處理的場景下,不同進程之間的通訊和共享記憶體成為了程式開發的關鍵問題。本文將介紹在Golang中實作多進程之間共享記憶體的應用方法。一、Golang中多進程的實作方式在Golang中,可以透過多種方式實現多進程並發處理,其中包括fork、os.Process、

事件循環是 Node.js 的基本組成部分,透過確保主執行緒不被阻塞來實現非同步編程,了解事件循環對建立高效應用程式至關重要。以下這篇文章就來帶大家深入了解Node中的事件循環 ,希望對大家有幫助!

node無法用npm指令是因為沒有正確配置環境變量,其解決方法是:1、開啟“系統屬性”;2、找到“環境變數”->“系統變數”,然後編輯環境變數;3、找到nodejs所在的資料夾;4、點選「確定」即可。

一開始的時候 JS 只在瀏覽器端運行,對於 Unicode 編碼的字串容易處理,但對於二進位和非 Unicode 編碼的字串處理困難。並且二進制是電腦最底層的資料格式,視訊/音訊/程式/網路包

如何使用 Node.js 進行前端應用的開發?以下這篇文章為大家介紹一下Node開發前端應用的方法,涉及到表現層應用的開發。我今天分享的方案是針對簡單場景的,旨在讓前端開發人員不必掌握太多關於 Node.js 的背景知識和專業知識,即使沒有程式碼編寫經驗,也能完成一些簡單的服務端開發任務。
