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!
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.
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.
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“]
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:
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:
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); } })();
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); } })();
Unterstützte Flags sind 3:
const flags = COPYFILE_FICLONE | COPYFILE_EXCL; fsPromises.copyFile('source.txt', 'destination.txt', flags);
Aber 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}`); }
exec:
const { exec } = require('child_process'); exec('my.bat', (err, stdout, stderr) => { if (err) { console.error(err); return; } console.log(stdout); });
fork ist die Grundlage für die Linux-Prozesserstellung, was zeigt, wie wichtig die Copy-on-Write-Technologie ist.
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!