ホームページ > ウェブフロントエンド > jsチュートリアル > Child_process は Node.js で複数のプロセスを実装します。

Child_process は Node.js で複数のプロセスを実装します。

高洛峰
リリース: 2016-12-26 09:14:54
オリジナル
1365 人が閲覧しました

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);
ログイン後にコピー

上記の例は、フィボナッチ数列計算サービスを提供します。この計算は非常に時間がかかり、シングルスレッドであるため、同時に複数のリクエストがある場合は 1 つしか処理できません。これは child_process.fork( ) 質問

これは公式Webサイトから引用した例です。この例を通して、fork()の機能をよりよく理解できます

var cp = require(&#39;child_process&#39;);
var n = cp.fork(__dirname + &#39;/sub.js&#39;);
n.on(&#39;message&#39;, function(m) {
  console.log(&#39;PARENT got message:&#39;, m);
});
n.send({ hello: &#39;world&#39; });
ログイン後にコピー

上記のコードスニペットを実行した結果:

PARENT got message: { foo: &#39;bar&#39; }
CHILD got message: { hello: &#39;world&#39; }
ログイン後にコピー

sub.jsの内容は次のとおりです。次のように:

process.on(&#39;message&#39;, function(m) {
  console.log(&#39;CHILD got message:&#39;, m);
});
process.send({ foo: &#39;bar&#39; });
ログイン後にコピー

In 子プロセスのプロセス オブジェクトには send() メソッドがあり、メッセージを受信するたびにメッセージ オブジェクトをパブリッシュします。 ) は process.on() メソッドで受信され、 process.send() メソッドで送信されたメッセージは child.on() メソッドで受信されます

この例を参照すると、フィボナッチを提供する最初のサービスを改善できます。各リクエストが個別に処理されるようにデータを作成します

var http = require(&#39;http&#39;);
var cp = require(&#39;child_process&#39;);
var server = http.createServer(function(req, res) {
    var child = cp.fork(__dirname + &#39;/fibonacci-calc.js&#39;);//每个请求都单独生成一个新的子进程
    child.on(&#39;message&#39;, function(m) {
        res.end(m.result + &#39;\n&#39;);
    });
    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(&#39;message&#39;, function(m) {
    process.send({result: fib(m.input)});
});
ログイン後にコピー

サービスを開始した後、http://localhost:8080/9 にアクセスして、フィボナッチ数列 9 の値を計算します

この記事は以上です。皆さんに気に入っていただければ幸いです。

Node.js での child_process のマルチプロセス実装に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート