Inhaltsverzeichnis
Dateikopie
Fork ist eine gängige Methode zum Erstellen eines Prozesses und seine Implementierung ist eine Copy-on-Write-Technologie. Wir wissen, dass der Prozess im Speicher in drei Teile unterteilt ist: Codesegment, Datensegment und Stapelsegment:
Zusammenfassung
Heim Web-Frontend js-Tutorial Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien

Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien

Sep 17, 2021 am 10:07 AM
node.js 文件复制

In diesem Artikel lernen Sie die COW-Technologie (Copy-On-Write) kennen und stellen die Anwendung der COW-Technologie zur Prozesserstellung und zum Kopieren von Dateien vor. + Node.js Ich hoffe, dass er für alle hilfreich ist!

Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien

COW ist keine Kuh, es ist die Abkürzung für Copy-On-Write, eine Technologie, die kopiert, aber nicht genau kopiert.

Im Allgemeinen werden beim Kopieren zwei identische Kopien erstellt.

Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien

Manchmal ist das Kopieren jedoch nicht erforderlich und Sie können die vorherige Kopie vollständig wiederverwenden Kopieren Sie beim Schreiben des Inhalts nur den entsprechenden Teil. Auf diese Weise entfällt das Kopieren, wenn der Inhalt zum Lesen verwendet wird. Wenn jedoch Schreiben erforderlich ist, wird ein Teil des Inhalts tatsächlich zur Änderung kopiert.

Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien

Das nennt man „Copy-on-Write“, auch Copy-On-Write genannt.

Das Prinzip ist sehr einfach, aber auch in der Speicherverwaltung und im Dateisystem des Betriebssystems ist Node.js aufgrund dieser Technologie „faul“ geworden.

In diesem Artikel werden wir die Anwendung von Copy-On-Write bei der Prozesserstellung und dem Kopieren von Dateien in Node.js untersuchen. [Empfohlenes Lernen: „nodejs-Tutorial“]

Dateikopie

Die häufigste Idee zum Kopieren von Dateien besteht darin, denselben Dateiinhalt vollständig an einen anderen Ort zu schreiben. Dabei gibt es jedoch zwei Probleme:

  • Schreiben genau derselbe Inhalt, wenn dieselbe Datei hunderte Male kopiert wird, wird dann derselbe Inhalt hunderte Male erstellt? Was für eine Verschwendung von Festplattenspeicher
  • Was passiert, wenn beim Schreiben der Strom ausfällt? Wie kann ich überschriebene Inhalte wiederherstellen?

Was soll ich tun? Zu diesem Zeitpunkt dachten Betriebssystemdesigner an die COW-Technologie.

Der Einsatz der COW-Technologie zum Kopieren von Dateien löst die beiden oben genannten Probleme perfekt:

  • Durch das Kopieren wird lediglich ein Verweis auf den vorherigen Inhalt hinzugefügt Wird zum ersten Mal geändert, werden die entsprechenden Datenblöcke tatsächlich kopiert, wodurch vermieden wird, dass viel Festplattenspeicher verschwendet wird.
  • Beim Schreiben einer Datei werden zunächst Änderungen an einem anderen freien Festplattenblock vorgenommen und nach Abschluss der Änderungen an den Zielspeicherort kopiert, sodass nach einem Stromausfall kein Rollback mehr möglich ist.

In der fs.copyFile-API von Node.js können Sie den Copy-On-Write-Modus verwenden:

Standardmäßig schreibt copyFile in die Zieldatei und überschreibt den ursprünglichen Inhalt

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

(async function() {
  try {
    await fsPromises.copyFile('source.txt', 'destination.txt');
  } catch(e) {
    console.log(e.message);
  }
})();
Nach dem Login kopieren

Aber Sie können die Kopierstrategie über den dritten festlegen Parameter:

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);
  }
})();
Nach dem Login kopieren

Unterstützte Flags sind 3:

  • COPYFILE_EXCL: Wenn die Zieldatei bereits vorhanden ist, wird ein Fehler gemeldet (standardmäßig wird überschrieben). Das System unterstützt es nicht, es wechselt zum echten Kopieren (Standard ist direktes Kopieren).
  • COPYFILE_FICLONE_FORCE: Kopieren im Copy-on-Write-Modus. Wenn das Betriebssystem dies nicht unterstützt, wird ein Fehler gemeldet
  • Diese drei Konstanten sind 1, 2 und 4. Sie können durch bitweises ODER kombiniert und übergeben werden:
  • const flags = COPYFILE_FICLONE | COPYFILE_EXCL;
    fsPromises.copyFile('source.txt', 'destination.txt', flags);
    Nach dem Login kopieren
  • Node.js unterstützt die Copy-on-Write-Technologie des Betriebssystems, was in einigen Szenarien die Leistung verbessern kann. Es wird empfohlen, die Methode COPYFILE_FICLONE zu verwenden, die besser als die Standardmethode ist.

Prozesserstellung

Fork ist eine gängige Methode zum Erstellen eines Prozesses und seine Implementierung ist eine Copy-on-Write-Technologie. Wir wissen, dass der Prozess im Speicher in drei Teile unterteilt ist: Codesegment, Datensegment und Stapelsegment:

Codesegment: Speichert den auszuführenden Code

Datensegment: Speichert einige globale Daten
  • Stapel Segment: speichert die Ausführung Der Status
  • Wenn ein neuer Prozess basierend auf diesem Prozess erstellt wird, müssen diese 3 Teile des Speichers kopiert werden. Und wenn diese drei Teile des Speichers den gleichen Inhalt haben, dann wird Speicherplatz verschwendet.
  • Fork kopiert also nicht wirklich den Speicher, sondern erstellt einen neuen Prozess und referenziert den Speicher des übergeordneten Prozesses. Wenn die Daten geändert werden, wird dieser Teil des Speichers tatsächlich kopiert.

Aus diesem Grund wird die Prozesserstellung als Fork bezeichnet, das heißt Fork, weil sie nicht völlig unabhängig ist, sondern einige Teile in zwei Teile gespalten sind, die meisten jedoch immer noch gleich sind.

Eine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von DateienAber was ist, wenn der auszuführende Code anders ist? Zu diesem Zeitpunkt müssen Sie exec verwenden, um ein neues Codesegment, Datensegment und Stapelsegment zu erstellen und neuen Code auszuführen.

Sie können auch die Fork- und Exec-APIs in Node.js verwenden:

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}`);
}
Nach dem Login kopieren

exec:

const { exec } = require('child_process');
exec('my.bat', (err, stdout, stderr) => {
  if (err) {
    console.error(err);
    return;
  }
  console.log(stdout);
});
Nach dem Login kopieren

fork ist die Grundlage für die Linux-Prozesserstellung, was zeigt, wie wichtig die Copy-on-Write-Technologie ist.

Zusammenfassung

Das Kopieren mehrerer Kopien desselben Inhalts ist zweifellos eine Platzverschwendung. Daher verwendet das Betriebssystem beim Kopieren von Dateien und beim Kopieren von Speicher nur bei tatsächlichen Änderungen Gehen Sie und machen Sie eine Kopie.

Node.js unterstützt das Setzen von Flags von fs.copyFile. Sie können COPYFILE_FICLONE angeben, um die Copy-On-Write-Methode zum Kopieren von Dateien zu verwenden. Es wird außerdem empfohlen, diese Methode zu verwenden, um Festplattenspeicher zu sparen und die Leistung zu verbessern des Dateikopierens.

Der Fork eines Prozesses ist ebenfalls eine Implementierung von Copy-On-Write. Er kopiert das Codesegment, das Datensegment und das Stapelsegment des Prozesses nicht direkt in den neuen Inhalt, sondern bezieht sich nur auf den vorherigen es wird die echte Speicherkopie sein.

Darüber hinaus hat Copy-On-Write viele Anwendungen in der Implementierung von Immutable und in der verteilten Lese-/Schreibtrennung und anderen Bereichen.

COW macht Node.js „faul“, bietet aber eine bessere Leistung.

Ursprüngliche Adresse: https://juejin.cn/post/6999497362255118366

Autor: zxg_Gott sagte, es muss Licht sein

Weitere Kenntnisse im Bereich Programmierung finden Sie unter: Einführung in die Programmierung! !

Das obige ist der detaillierte Inhalt vonEine kurze Diskussion über die Node.js+COW-Technologie für die Prozesserstellung und das Kopieren von Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Nov 16, 2022 pm 08:34 PM

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Nov 29, 2022 pm 08:44 PM

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Dec 02, 2022 pm 09:06 PM

Wie packe ich die ausführbare Datei von nodejs mit pkg? Im folgenden Artikel erfahren Sie, wie Sie mit pkg ein Node-Projekt in eine ausführbare Datei packen. Ich hoffe, dass er Ihnen weiterhilft!

See all articles