プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明
この記事では、COW (Copy-On-Write) テクノロジを理解し、COW テクノロジのプロセス作成とファイル コピーのアプリケーション Node.js を紹介します。
COW は牛ではなく、Copy-On-Write の略で、コピーはするが完全にはコピーしない技術です。
一般的に、コピーとは 2 つの同一のコピーを作成することです。2 つのコピーは独立しています:
ただし、場合によっては、コピーが機能しないことがあります。 , 以前のものを再利用することができますが、このとき、内容を書く際には、以前のものを引用し、内容の該当部分をコピーするだけで大丈夫です。このように、コンテンツが読み取りに使用される場合にはコピーは不要ですが、書き込みが必要な場合には、実際にはコンテンツの一部がコピーされて変更されます。
これは「コピーオンライト」と呼ばれ、コピーオンライトとも呼ばれます。
原理は非常に単純ですが、オペレーティング システムのメモリ管理とファイル システムでは非常に一般的であり、Node.js もこのテクノロジのせいで「遅延」になっています。
この記事では、Node.js でのプロセス作成とファイルのコピーにおけるコピーオンライトの応用について見ていきます。 [推奨学習: "nodejs チュートリアル"]
ファイル コピー
ファイル コピーの最も一般的なアイデアは、完全に同一のコピー ファイルを作成することです。
- まったく同じコンテンツを書き込む同じファイルを何百回もコピーすると、同じコンテンツが何百回も作成されることになります。 ?ハードディスク容量の無駄です。
- 書き込み途中で電源が切れたらどうなりますか?上書きされたコンテンツを復元するにはどうすればよいですか? #########どうやってするの?この時点で、オペレーティング システムの設計者は COW テクノロジを思いつきました。
コピーすると、前のコンテンツへの参照が追加されるだけです。変更されなければ、実際にはコピーされません。コピーのみ コンテンツが初めて変更されるまで、対応するデータ ブロックは実際にはコピーされないため、大量のハードディスク領域の無駄が回避されます。
- ファイルを書き込むとき、最初に別の空きディスク ブロックに変更が行われ、変更が完了した後にターゲットの場所にコピーされるため、後でロールバックできないという問題は発生しません。停電
- Node.js の fs.copyFile API でコピーオンライト モードを使用できます。
const fsPromises = require('fs').promises; (async function() { try { await fsPromises.copyFile('source.txt', 'destination.txt'); } catch(e) { console.log(e.message); } })();
const fs = require('fs'); const fsPromises = fs.promises; const { COPYFILE_EXCL, COPYFILE_FICLONE, COPYFILE_FICLONE_FORCE} = fs.constants; (async function() { try { await fsPromises.copyFile('source.txt', 'destination.txt', COPYFILE_FICLONE); } catch(e) { console.log(e.message); } })();
COPYFILE_EXCL: ターゲット ファイルの場合すでに存在する場合、エラーが報告されます (デフォルトは上書きです)
- COPYFILE_FICLONE: コピーオンライト モードでコピーします。オペレーティング システムがこれをサポートしていない場合は、実際のコピー (デフォルト) に切り替わります。は直接コピーです) COPYFILE_FICLONE_FORCE: コピーオンライト モードでコピーします。オペレーティング システムがサポートしていない場合、エラーが報告されます。
- これら 3 つの定数は 1
const flags = COPYFILE_FICLONE | COPYFILE_EXCL; fsPromises.copyFile('source.txt', 'destination.txt', flags);
プロセスの作成
フォークはプロセスを作成する一般的な方法であり、その実装はコピーオンライトテクノロジです。
プロセスはメモリ内でコード セグメント、データ セグメント、スタック セグメントの 3 つの部分に分割されていることがわかります。コード セグメント: 実行されるコードを格納します
- データ セグメント: グローバル データを格納します。スタック セグメント: 実行ステータスを格納します。
- このプロセスに基づいて新しいプロセスが作成される場合、メモリのこれら 3 つの部分は、コピーされました。そして、メモリのこれら 3 つの部分が同じ内容を持つ場合、メモリ領域が無駄になります。
これが、プロセスの作成がフォークと呼ばれる理由です。これは、完全に独立しているわけではなく、特定の部分が 2 つの部分に分岐しているためです。しかし、そのほとんどはまだ同じです。
const cluster = require('cluster'); if (cluster.isMaster) { console.log('I am master'); cluster.fork(); cluster.fork(); } else if (cluster.isWorker) { console.log(`I am worker #${cluster.worker.id}`); }
const { exec } = require('child_process'); exec('my.bat', (err, stdout, stderr) => { if (err) { console.error(err); return; } console.log(stdout); });
概要
同じコンテンツの複数のコピーをコピーすることは間違いなくスペースの無駄であるため、オペレーティング システムは、プロセス作成時にファイルをコピーしたりメモリをコピーしたりするときにコピーオンを使用します。テクノロジーは、実際に変更された場合にのみコピーされます。
Node.js は、fs.copyFile のフラグの設定をサポートしています。COPYFILE_FICLONE を指定すると、コピーオンライトを使用してファイルをコピーできます。また、ハード ディスクのスペースを節約し、パフォーマンスを向上させるために、この方法を使用することをお勧めします。ファイルコピーのパフォーマンス。
プロセスのフォークもコピーオンライトの実装です。プロセスのコード セグメント、データ セグメント、スタック セグメントを新しいコンテンツに直接コピーするのではなく、以前のコンテンツを参照します。実メモリのコピーを実行します。
さらに、コピーオンライトは、Immutable の実装や分散読み取り/書き込み分離などの分野で多くの用途があります。
COW は Node.js を「遅延」させますが、パフォーマンスは向上します。
元のアドレス: https://juejin.cn/post/6999497362255118366
作者: zxg_God は光があるに違いないと言いました
その他のプログラミング関連知識については、プログラミング入門をご覧ください。 !
以上がプロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











この記事では、NodeJS V8 エンジンのメモリとガベージ コレクター (GC) について詳しく説明します。

ノンブロッキングおよびイベント駆動に基づいて構築されたノード サービスには、メモリ消費量が少ないという利点があり、大量のネットワーク リクエストの処理に非常に適しています。大量のリクエストを前提として、「メモリ制御」に関する問題を考慮する必要があります。 1. V8 のガベージ コレクション メカニズムとメモリ制限 Js はガベージ コレクション マシンによって制御されます

ノード用の Docker イメージの選択は些細なことのように思えるかもしれませんが、イメージのサイズと潜在的な脆弱性は、CI/CD プロセスとセキュリティに大きな影響を与える可能性があります。では、最適な Node.js Docker イメージを選択するにはどうすればよいでしょうか?

ファイル モジュールは、ファイルの読み取り/書き込み/開く/閉じる/削除の追加など、基礎となるファイル操作をカプセル化したものです。ファイル モジュールの最大の特徴は、すべてのメソッドが **同期** と ** の 2 つのバージョンを提供することです。 asynchronous**、sync サフィックスが付いているメソッドはすべて同期メソッドであり、持たないメソッドはすべて異種メソッドです。

Node 19 が正式リリースされましたので、この記事では Node.js 19 の 6 つの主要な機能について詳しく説明します。

Node.js はどのように GC (ガベージ コレクション) を行うのでしょうか?次の記事で詳しく説明します。

イベント ループは Node.js の基本的な部分であり、メイン スレッドがブロックされていないことを確認することで非同期プログラミングが可能になります。イベント ループを理解することは、効率的なアプリケーションを構築するために重要です。次の記事では、Node のイベント ループについて詳しく説明します。お役に立てれば幸いです。

当初、JS はブラウザ側でのみ動作していたため、Unicode でエンコードされた文字列の処理は簡単でしたが、バイナリ文字列や非 Unicode エンコード文字列の処理は困難でした。バイナリは、コンピュータのビデオ/オーディオ/プログラム/ネットワーク パッケージの最低レベルのデータ形式です。
