概要Nodejs は Chrome ブラウザの V8 エンジンに基づいて構築されているため、そのモデルはブラウザのモデルに似ています。 JavaScript は単一プロセス内の単一スレッドで実行されます。 しかし、V8エンジンのシングルプロセス、シングルスレッド構造は完璧な構造ではありません。昨今のCPUは基本的にマルチコアです。実際のサーバーには複数の CPU が搭載されていることがよくあります (オンラインの物理マシンには 12 個のコアが搭載されているなど)。そのため、Nodejs の実際の適用では、「マルチコア CPU サーバーを最大限に活用するにはどうすればよいか」という疑問が生じます。 厳密に言えば、Node は真のシングルスレッド アーキテクチャではありません。Node 自体に I/O スレッド (ネットワーク I/O、ディスク I/O) があるためです。これらの I/O スレッドは、JavaScript 開発者にとって透過的な低レベルの libuv によって処理されます。 JavaScript コードは常に V8 上で実行され、シングルスレッドです。したがって、表面的には NodeJS はシングルスレッドです。 node.js でマルチコア CPU を最大限に活用する方法シングルプロセスおよびシングルスレッドのマルチコア利用率が低いという問題に直面していますが、これまでの経験によれば、各プロセスは 1 つの CPU を使用してマルチコア CPU の利用を実現できます。 Node は、child_process モジュールを提供し、プロセスのレプリケーションを実装するための fork() メソッドも提供します (プロセスがレプリケーションされる限り、一定のリソースと時間が必要です。Node では、プロセスをレプリケーションするために 10 MB 以上のメモリと 30 ミリ秒以上が必要です)。 このようなソリューションは、*nix システムで最も古典的なマスター ワーカー モードであり、マスター スレーブ モードとも呼ばれます。 典型的な並列処理ビジネス モデルのこの分散アーキテクチャは、優れたスケーラビリティ (スケーラビリティは、実際には並列アルゴリズムおよび並列コンピュータ アーキテクチャと一緒に議論されます。特定のマシン上のアルゴリズムのスケーラビリティは、アルゴリズムが増加する CPU の数を効果的に利用できるかどうかを反映します) と安定性を備えています。 メインプロセスは特定の業務処理を担当するのではなく、作業プロセスのスケジュールと管理を担当します。作業プロセスは特定の業務処理を担当するため、開発者は作業プロセスの安定性に注意を払う必要があります。 fork() によってコピーされたプロセスは独立したプロセスであり、独立した新しい V8 インスタンスを持ちます。 Node は各 CPU コアを使用できるようにプロセスをコピーする fork() を提供していますが、fork() プロセスは非常にコストがかかるということを覚えておくことが重要です。幸いなことに、Node はイベント駆動を通じて単一のスレッドで大規模な同時リクエストを処理できます。 注: ここで複数のプロセスを開始するのは、CPU リソースを最大限に活用するためであり、同時実行の問題を解決するためではありません。 Node で子プロセスを作成する 4 つの方法1. スポーン() コマンドを実行するサブプロセスを作成する 2. 実行() コマンドを実行するための子プロセスを作成します。spawn() との違いは、メソッドのパラメータが異なることです。子プロセスのステータスを取得するためにコールバック関数を渡すことができます。 3. execFile() 指定されたファイルを実行するサブプロセスを開始します。プロセス タイプを指定するには、ファイルの先頭で SHEBANG シンボル (#!) を宣言する必要があることに注意してください。 4. フォーク() spawn() と似ていますが、違いは、Node 子プロセスを作成するために JavaScript ファイル モジュールを実行するだけでよいことです。 注: 次の 3 つのメソッドは、spawn() の拡張アプリケーションです。 上記は、node.js がマルチコア CPU を最大限に活用する方法の詳細です。node.js がマルチコア CPU を最大限に活用する方法の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: CentOS プラットフォーム上で LAMP 環境を素早く構築する方法
>>: LinuxベースのApacheウェブサイトサービス構成の詳細な説明
0. タグとは何ですか? XML/HTML コードコンテンツをクリップボードにコピー<入力 t...
CentOS プロジェクトは、Red Hat の再配布要件に完全に準拠した、Red Hat Ente...
RDF と OWL は、2 つの重要なセマンティック ウェブ テクノロジーです。 RDF と OWL...
以下の機能が実装されています。 1. ユーザー名: onfouc は msg ルールを表示します。o...
Docker サービス アプリケーションを再起動するコマンドを見てみましょう。具体的な内容は次のと...
この記事は、参考のためにMySQL 8.0.16のインストールグラフィックチュートリアルを記録してい...
スワップを無効にするサーバーがデータベース サービスまたはメッセージ ミドルウェア サービスを実行し...
jquery-multiselect (ドロップダウン ボックスをチェックボックス付きの複数選択コン...
1つ。 tomcat を使用したリモート展開1.1 発生した問題:プロジェクトでは、サードパーティの...
目次序文ベジェ曲線の紹介二次ベジェ曲線3次ベジェ曲線ベジェ曲線計算機能フィッティングアルゴリズム付録...
参考までに、HTMLフォームの使い方を9つの簡単な例で分析します。具体的な内容は次のとおりです。 1...
場合によっては、ユーザーがボタンをクリックして同様のフォームを追加し、クリックごとに 1 回追加でき...
MySQL 8.0.21のインストールと設定方法を記録してみんなで共有します。 1. ダウンロード1...
div がネストされているときに margin が機能しない問題の解決策を次に示します。さて、マージ...
目次1. フォークの起源2. 初期のUNIXオーバーレイ技術3. UNIXに導入される前のフォークの...