この記事では、Node.js のサブプロセスを理解し、Node.js でサブプロセスを作成する 4 つの方法を紹介します。皆様のお役に立てれば幸いです。
ご存知のとおり、Node.js はシングルスレッド、非同期、ノンブロッキングのプログラミング言語です。 CPU?これには、子プロセスを作成するための child_process モジュールが必要です。Node.js では、子プロセスを作成するには 4 つの方法があります:
exec
execFile
##spawn
-
fork
nodejs チュートリアル "]
上記 4 つのメソッドはChildProcess を返します インスタンス (
EventEmitter から継承)。これには 3 つの標準 stdio ストリームがあります:
-
child.stdin
child.stdout
- ##child.stderr
: 子プロセスの終了時にトリガーされ、パラメータはコード エラー コードとシグナル割り込みシグナルです。
: 子プロセスが終了し、stdio ストリームが閉じられるとトリガーされます。パラメータは exit
イベントと同じです。
: 親プロセスが child.disconnect()
を呼び出すか、子プロセスが process.disconnect()
を呼び出すとトリガーされます。
: 子プロセスを作成できない場合、強制終了できない場合、または子プロセスへのメッセージの送信に失敗した場合にトリガーされます。
: 子プロセスが process.send()
を通じてメッセージを送信するとトリガーされます。
: 子プロセスが正常に作成されたときにトリガーされます (このイベントは Node.js v15.1 でのみ追加されました)。
メソッドと execFile
メソッドは、子プロセスの終了時にトリガーされる追加のコールバック関数も提供します。次に、詳細な分析を行います。 exec
exec メソッドは bash コマンドの実行に使用され、そのパラメータはコマンド文字列です。たとえば、現在のディレクトリ内のファイルの数をカウントするには、exec 関数は次のように記述されます。
const { exec } = require("child_process") exec("find . -type f | wc -l", (err, stdout, stderr) => { if (err) return console.error(`exec error: ${err}`) console.log(`Number of files ${stdout}`) })
exec は、新しいサブプロセスを作成し、その実行結果をキャッシュし、実行後にコールバック関数を呼び出します。完成されました。
exec コマンドは比較的危険だと思われたかもしれませんが、ユーザーが指定した文字列を exec 関数のパラメーターとして使用すると、次のようなコマンド ライン インジェクションのリスクに直面することになります。 #
find . -type f | wc -l; rm -rf /;さらに、exec はすべての出力結果をメモリにキャッシュするため、データが比較的大きい場合は、spawn の方が適切な選択肢になります。 execFileexecFile と exec の違いは、シェルを作成せず、コマンドを直接実行するため、より効率的です。例:
const { execFile } = require("child_process")
const child = execFile("node", ["--version"], (error, stdout, stderr) => {
if (error) throw error
console.log(stdout)
})
作成シェルがないため、プログラムのパラメータが配列として渡されるため、安全性が高いです。 spawnspawn 関数は execFile に似ています。デフォルトではシェルは開かれませんが、異なる点は、execFile がコマンド ラインの出力をキャッシュし、その結果をコールバックに渡すことです。関数では、spawn はストリーム出力を使用しますが、ストリームを使用すると、入力と出力を接続するのに非常に便利です。たとえば、典型的な wc
コマンド:const child = spawn("wc") process.stdin.pipe(child.stdin) child.stdout.on("data", data => { console.log(`child stdout:\n${data}`) })
このとき、入力はユーザーが復帰
ctrl D をトリガーすると、コマンドの実行が開始され、結果が標準出力から出力されます。 wc は Word Count の略語で、単語数をカウントするために使用されます。構文は次のとおりです:
wc [OPTION]... [FILE]...
ターミナルで wc コマンドを入力して Enter キーを押すと、 、カウントはキーボードからのものです。ターミナルに文字を入力し、もう一度 Enter キーを押し、Node.js での記述方法 コマンド ラインとまったく同じです:Ctrl D
を押して統計結果を出力します。
現在のディレクトリ内のファイル数を数えるなど、パイプラインを介して複雑なコマンドを組み合わせることができます。Linux コマンド ラインでは、次のように記述されます:
find . -type f | wc -l
const find = spawn("find", [".", "-type", "f"]) const wc = spawn("wc", ["-l"]) find.stdout.pipe(wc.stdin) wc.stdout.on("data", (data) => { console.log(`Number of files ${data}`) })spawn には豊富なカスタム構成があります。たとえば:
const child = spawn("find . -type f | wc -l", { stdio: "inherit", // 继承父进程的输入输出流 shell: true, // 开启命令行模式 cwd: "/Users/keliq/code", // 指定执行目录 env: { ANSWER: 42 }, // 指定环境变量(默认是 process.env) detached: true, // 作为独立进程存在 })fork fork 関数は次のとおりです。 fork によって作成された子を使用する spawn 関数のバリアント。プロセスと親プロセスの間に通信チャネルが自動的に作成され、send メソッドが子プロセスのグローバル オブジェクト プロセスにマウントされます。たとえば、親プロセスのparent.jsコード:
const { fork } = require("child_process")
const forked = fork("./child.js")
forked.on("message", msg => {
console.log("Message from child", msg);
})
forked.send({ hello: "world" })
子プロセスのchild.jsコード: process.on("message", msg => { console.log("Message from parent:", msg) }) let counter = 0 setInterval(() => { process.send({ counter: counter++ }) }, 1000)
fork("child.js")
を呼び出すとき、実際には、node を使用してファイル内のコードを実行するだけです。これは、spawn('node', ['./child.js']) と同等です。
fork の一般的なアプリケーション シナリオは次のとおりです。 Node.js を使用して http サービスを作成する場合、ルートが
compute
const http = require("http") const server = http.createServer() server.on("request", (req, res) => { if (req.url === "/compute") { const sum = longComputation() return res.end(Sum is ${sum}) } else { res.end("OK") } }) server.listen(3000);
次のコードを使用して、この時間のかかる操作をシミュレートできます:
const longComputation = () => { let sum = 0; for (let i = 0; i < 1e9; i++) { sum += i } return sum }
那么在上线后,只要服务端收到了 compute
请求,由于 Node.js 是单线程的,耗时运算占用了 CPU,用户的其他请求都会阻塞在这里,表现出来的现象就是服务器无响应。
解决这个问题最简单的方法就是把耗时运算放到子进程中去处理,例如创建一个 compute.js
的文件,代码如下:
const longComputation = () => { let sum = 0; for (let i = 0; i < 1e9; i++) { sum += i; } return sum } process.on("message", msg => { const sum = longComputation() process.send(sum) })
再把服务端的代码稍作改造:
const http = require("http") const { fork } = require("child_process") const server = http.createServer() server.on("request", (req, res) => { if (req.url === "/compute") { const compute = fork("compute.js") compute.send("start") compute.on("message", sum => { res.end(Sum is ${sum}) }) } else { res.end("OK") } }) server.listen(3000)
这样的话,主线程就不会阻塞,而是继续处理其他的请求,当耗时运算的结果返回后,再做出响应。其实更简单的处理方式是利用 cluster 模块,限于篇幅原因,后面再展开讲。
总结
掌握了上面四种创建子进程的方法之后,总结了以下三条规律:
- 创建 node 子进程用 fork,因为自带通道方便通信。
- 创建非 node 子进程用 execFile 或 spawn。如果输出内容较少用 execFile,会缓存结果并传给回调方便处理;如果输出内容多用 spawn,使用流的方式不会占用大量内存。
- 执行复杂的、固定的终端命令用 exec,写起来更方便。但一定要记住 exec 会创建 shell,效率不如 execFile 和 spawn,且存在命令行注入的风险。
更多编程相关知识,请访问:编程视频!!
以上がNode.js で子プロセスを作成する方法の詳細な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

WebStorm Mac版
便利なJavaScript開発ツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Dreamweaver Mac版
ビジュアル Web 開発ツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。
