Nodejs がマルチスレッド処理を実行する方法についての簡単な説明
この記事では、Nodejs がどのようにマルチスレッド処理を行うのかを紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。
Threads à gogo は、nodejs のネイティブ モジュールであり、このモジュールを使用すると、nodejs にマルチスレッド処理機能を持たせることができます。 [推奨学習: "nodejs チュートリアル "]
インストール方法
npm install threads_a_gogo
テスト ソース コードのダウンロード
git clone http://github.com/xk/node-threads-a-gogo.git
モジュール コードのインポート
var tagg= require('threads_a_gogo');
API
tagg= require('threads_a_gogo') //生成tagg object var thread = tagg.create( /* no arguments */ ) //生成 thread object var thread_pool = tagg.createPool( numberOfThreads ) //生成 thread pool thread.load("boot.js").eval("boot()").emit("go").on("event", cb) //thread读取boot.js文件 执行boot(),发送event go,并且监听 event 事件 cb(err,result) thread_pool.load('path') //pool中的任意(.all 为全部)thread 读取path file pool.any.eval( program, cb ) //pool中的任意(.all 为全部)thread执行program
マルチスレッドを使用する理由
1. 並列実行、キュー不要、高速。
2. 公平性を保つため、すべてのスレッドは同じ優先度を持ちます。
3. リソースを最大限に活用し、より多くの CPU がタスク処理に参加できるようにします。
4. すべてのスレッドはストレージ アドレスを共有します。
例
まず簡単なテストを行い、フィボナッチ配列を使用してそれを確認し、マルチスレッド ノードを追加してみましょう。それは:(テスト マシンは 4CPU です)TAGG を通常に使用しないと、非同期は CPU を大量に使用するタスクを処理するのに役立ちません。
function fibo (n) { return n > 1 ? fibo(n - 1) + fibo(n - 2) : 1; } var n=8 function back(){ if(!--n) return console.timeEnd('no thread'); } console.time('no thread'); process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); }) process.nextTick(function(){ console.log(fibo (40)); back(); })
node v0 をテストするために、##8 の非同期動作をシミュレートしました。 8.16 バージョンでは、process.nextTick はまだ非同期メソッドです。最後に、出力結果は次のようになります:
165580141 165580141 165580141 165580141 165580141 165580141 165580141 165580141 no thread: 23346ms
function fibo (n) { return n > 1 ? fibo(n - 1) + fibo(n - 2) : 1; } console.time('8 thread'); var numThreads= 8; //创建线程池,最大数为8 var threadPool= require('threads_a_gogo').createPool(numThreads).all.eval(fibo); //为线程池注册程序 var i=8; var cb = function(err,data){ //注册线程执行完毕的回调函数 console.log(data); if(!--i){ threadPool.destroy(); console.timeEnd('8 thread'); } } threadPool.any.eval('fibo(40)', cb); //开始向线程池中执行fibo(40)这个任务 threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb); threadPool.any.eval('fibo(40)', cb);
165580141 165580141 165580141 165580141 165580141 165580141 165580141 165580141 8 thread: 9510ms
TAGG モジュールには、イベントのトリガー、スムーズな終了、スレッドの動作ステータスのチェックなど、他にも多くの機能があります。つまり、TAGG モジュールは、 ノードに新しい活力を注入します。 . node が批判されていた cpu 負荷の高いタスクの処理の問題は適切に解決されました。たとえ c コードが苦手でも、マルチスレッドで真に非互換のコードを簡単に書くことができます。 ノード プログラムをブロックしています。
プログラミング関連の知識について詳しくは、プログラミング教育をご覧ください。 !
以上がNodejs がマルチスレッド処理を実行する方法についての簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Node.js は、高いパフォーマンス、スケーラビリティ、クロスプラットフォーム サポート、豊富なエコシステム、開発の容易さなどの機能を備えているため、バックエンド フレームワークとして使用できます。

MySQL データベースに接続するには、次の手順に従う必要があります。 mysql2 ドライバーをインストールします。 mysql2.createConnection() を使用して、ホスト アドレス、ポート、ユーザー名、パスワード、データベース名を含む接続オブジェクトを作成します。 connection.query() を使用してクエリを実行します。最後に connection.end() を使用して接続を終了します。

Node.js には次のグローバル変数が存在します。 グローバル オブジェクト: グローバル コア モジュール: プロセス、コンソール、require ランタイム環境変数: __dirname、__filename、__line、__column 定数: unknown、null、NaN、Infinity、-Infinity

Node.js と Java の主な違いは、設計と機能です。 イベント駆動型とスレッド駆動型: Node.js はイベント駆動型で、Java はスレッド駆動型です。シングルスレッドとマルチスレッド: Node.js はシングルスレッドのイベント ループを使用し、Java はマルチスレッド アーキテクチャを使用します。ランタイム環境: Node.js は V8 JavaScript エンジン上で実行され、Java は JVM 上で実行されます。構文: Node.js は JavaScript 構文を使用し、Java は Java 構文を使用します。目的: Node.js は I/O 集中型のタスクに適しており、Java は大規模なエンタープライズ アプリケーションに適しています。

Node.js インストール ディレクトリには、npm と npm.cmd という 2 つの npm 関連ファイルがあります。違いは次のとおりです。拡張子が異なります。npm は実行可能ファイルで、npm.cmd はコマンド ウィンドウのショートカットです。 Windows ユーザー: npm.cmd はコマンド プロンプトから使用できますが、npm はコマンド ラインからのみ実行できます。互換性: npm.cmd は Windows システムに固有ですが、npm はクロスプラットフォームで使用できます。使用上の推奨事項: Windows ユーザーは npm.cmd を使用し、他のオペレーティング システムは npm を使用します。

はい、Node.js はバックエンド開発言語です。これは、サーバー側のビジネス ロジックの処理、データベース接続の管理、API の提供などのバックエンド開発に使用されます。

Node.js プロジェクトのサーバー デプロイメント手順: デプロイメント環境を準備します。サーバー アクセスの取得、Node.js のインストール、Git リポジトリのセットアップ。アプリケーションをビルドする: npm run build を使用して、デプロイ可能なコードと依存関係を生成します。コードをサーバーにアップロードします: Git またはファイル転送プロトコル経由。依存関係をインストールする: サーバーに SSH で接続し、npm install を使用してアプリケーションの依存関係をインストールします。アプリケーションを開始します。node Index.js などのコマンドを使用してアプリケーションを開始するか、pm2 などのプロセス マネージャーを使用します。リバース プロキシの構成 (オプション): Nginx や Apache などのリバース プロキシを使用して、トラフィックをアプリケーションにルーティングします。

Web 開発において Node.js と Java にはそれぞれ長所と短所があり、どちらを選択するかはプロジェクトの要件によって異なります。 Node.js はリアルタイム アプリケーション、迅速な開発、マイクロサービス アーキテクチャに優れており、Java はエンタープライズ グレードのサポート、パフォーマンス、セキュリティに優れています。
