目次
ファイル コピー
フォークはプロセスを作成する一般的な方法であり、その実装はコピーオンライトテクノロジです。
概要
ホームページ ウェブフロントエンド jsチュートリアル プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

Sep 17, 2021 am 10:07 AM
node.js ファイルコピー

この記事では、COW (Copy-On-Write) テクノロジを理解し、COW テクノロジのプロセス作成とファイル コピーのアプリケーション Node.js を紹介します。

プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

COW は牛ではなく、Copy-On-Write の略で、コピーはするが完全にはコピーしない技術です。

一般的に、コピーとは 2 つの同一のコピーを作成することです。2 つのコピーは独立しています:

プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

ただし、場合によっては、コピーが機能しないことがあります。 , 以前のものを再利用することができますが、このとき、内容を書く際には、以前のものを引用し、内容の該当部分をコピーするだけで大​​丈夫です。このように、コンテンツが読み取りに使用される場合にはコピーは不要ですが、書き込みが必要な場合には、実際にはコンテンツの一部がコピーされて変更されます。

プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

これは「コピーオンライト」と呼ばれ、コピーオンライトとも呼ばれます。

原理は非常に単純ですが、オペレーティング システムのメモリ管理とファイル システムでは非常に一般的であり、Node.js もこのテクノロジのせいで「遅延」になっています。

この記事では、Node.js でのプロセス作成とファイルのコピーにおけるコピーオンライトの応用について見ていきます。 [推奨学習: "nodejs チュートリアル"]

ファイル コピー

ファイル コピーの最も一般的なアイデアは、完全に同一のコピー ファイルを作成することです。

  • まったく同じコンテンツを書き込む同じファイルを何百回もコピーすると、同じコンテンツが何百回も作成されることになります。 ?ハードディスク容量の無駄です。
  • 書き込み途中で電源が切れたらどうなりますか?上書きされたコンテンツを復元するにはどうすればよいですか? #########どうやってするの?この時点で、オペレーティング システムの設計者は COW テクノロジを思いつきました。
COW テクノロジを使用してファイルのコピーを実現すると、上記の 2 つの問題が完全に解決されます:

コピーすると、前のコンテンツへの参照が追加されるだけです。変更されなければ、実際にはコピーされません。コピーのみ コンテンツが初めて変更されるまで、対応するデータ ブロックは実際にはコピーされないため、大量のハードディスク領域の無駄が回避されます。

    ファイルを書き込むとき、最初に別の空きディスク ブロックに変更が行われ、変更が完了した後にターゲットの場所にコピーされるため、後でロールバックできないという問題は発生しません。停電
  • Node.js の fs.copyFile API でコピーオンライト モードを使用できます。
デフォルトでは、copyFile はターゲット ファイルに書き込み、上書きします。元のコンテンツ

const fsPromises = require('fs').promises;

(async function() {
  try {
    await fsPromises.copyFile('source.txt', 'destination.txt');
  } catch(e) {
    console.log(e.message);
  }
})();
ログイン後にコピー

ただし、3番目のパラメータを使用してコピー戦略を指定できます:

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

サポートされているフラグは3つあります:

COPYFILE_EXCL: ターゲット ファイルの場合すでに存在する場合、エラーが報告されます (デフォルトは上書きです)

    COPYFILE_FICLONE: コピーオンライト モードでコピーします。オペレーティング システムがこれをサポートしていない場合は、実際のコピー (デフォルト) に切り替わります。は直接コピーです)
  • COPYFILE_FICLONE_FORCE: コピーオンライト モードでコピーします。オペレーティング システムがサポートしていない場合、エラーが報告されます。
  • これら 3 つの定数は 1
  • const flags = COPYFILE_FICLONE | COPYFILE_EXCL;
    fsPromises.copyFile('source.txt', 'destination.txt', flags);
    ログイン後にコピー
Node.js オペレーティング システムのコピーオンライト テクノロジをサポートしており、一部のシナリオでパフォーマンスを向上させることができます。 COPYFILE_FICLONE メソッドを使用することをお勧めします。これはデフォルトのメソッドよりも優れています。

プロセスの作成

フォークはプロセスを作成する一般的な方法であり、その実装はコピーオンライトテクノロジです。

プロセスはメモリ内でコード セグメント、データ セグメント、スタック セグメントの 3 つの部分に分割されていることがわかります。

コード セグメント: 実行されるコードを格納します

    データ セグメント: グローバル データを格納します。
  • スタック セグメント: 実行ステータスを格納します。
  • このプロセスに基づいて新しいプロセスが作成される場合、メモリのこれら 3 つの部分は、コピーされました。そして、メモリのこれら 3 つの部分が同じ内容を持つ場合、メモリ領域が無駄になります。
したがって、fork は実際にはメモリをコピーするのではなく、新しいプロセスを作成し、親プロセスのメモリを参照します。データが変更されると、メモリのこの部分が実際にコピーされます。

これが、プロセスの作成がフォークと呼ばれる理由です。これは、完全に独立しているわけではなく、特定の部分が 2 つの部分に分岐しているためです。しかし、そのほとんどはまだ同じです。 プロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明

しかし、実行されるコードが異なる場合はどうなるでしょうか? この時点では、新しいコード セグメント、データ セグメント、スタック セグメントを作成し、新しいコードを実行する exec を使用する必要があります。

fork および exec API は Node.js でも使用できます。

fork:

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

exec:

const { exec } = require('child_process');
exec('my.bat', (err, stdout, stderr) => {
  if (err) {
    console.error(err);
    return;
  }
  console.log(stdout);
});
ログイン後にコピー

fork は Linux の基礎ですプロセスの作成 、これはコピーオンライトテクノロジがいかに重要であるかを示しています。

概要

同じコンテンツの複数のコピーをコピーすることは間違いなくスペースの無駄であるため、オペレーティング システムは、プロセス作成時にファイルをコピーしたりメモリをコピーしたりするときにコピーオンを使用します。テクノロジーは、実際に変更された場合にのみコピーされます。

Node.js は、fs.copyFile のフラグの設定をサポートしています。COPYFILE_FICLONE を指定すると、コピーオンライトを使用してファイルをコピーできます。また、ハード ディスクのスペースを節約し、パフォーマンスを向上させるために、この方法を使用することをお勧めします。ファイルコピーのパフォーマンス。

プロセスのフォークもコピーオンライトの実装です。プロセスのコード セグメント、データ セグメント、スタック セグメントを新しいコンテンツに直接コピーするのではなく、以前のコンテンツを参照します。実メモリのコピーを実行します。

さらに、コピーオンライトは、Immutable の実装や分散読み取り/書き込み分離などの分野で多くの用途があります。

COW は Node.js を「遅延」させますが、パフォーマンスは向上します。

元のアドレス: https://juejin.cn/post/6999497362255118366

作者: zxg_God は光があるに違いないと言いました

その他のプログラミング関連知識については、プログラミング入門をご覧ください。 !

以上がプロセス作成とファイルコピーのための Node.js+COW テクノロジーに関する簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Node V8 エンジンのメモリと GC の詳細な図による説明 Node V8 エンジンのメモリと GC の詳細な図による説明 Mar 29, 2023 pm 06:02 PM

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

Nodeのメモリ制御に関する記事 Nodeのメモリ制御に関する記事 Apr 26, 2023 pm 05:37 PM

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

最適な Node.js Docker イメージを選択する方法について話しましょう。 最適な Node.js Docker イメージを選択する方法について話しましょう。 Dec 13, 2022 pm 08:00 PM

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

Node の File モジュールについて詳しく説明しましょう Node の File モジュールについて詳しく説明しましょう Apr 24, 2023 pm 05:49 PM

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

Node.js 19 が正式リリースされました。その 6 つの主要な機能についてお話しましょう。 Node.js 19 が正式リリースされました。その 6 つの主要な機能についてお話しましょう。 Nov 16, 2022 pm 08:34 PM

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

Node.js の GC (ガベージ コレクション) メカニズムについて話しましょう Node.js の GC (ガベージ コレクション) メカニズムについて話しましょう Nov 29, 2022 pm 08:44 PM

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

Nodeのイベントループについて話しましょう Nodeのイベントループについて話しましょう Apr 11, 2023 pm 07:08 PM

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

ノードのバッファーについて詳しく見る ノードのバッファーについて詳しく見る Apr 25, 2023 pm 07:49 PM

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

See all articles