Heim >Web-Frontend >js-Tutorial >Node.js-Erste-Schritte-Tutorial

Node.js-Erste-Schritte-Tutorial

巴扎黑
巴扎黑Original
2017-08-22 17:01:191512Durchsuche

Node.js ist eine Plattform, die auf der Chrome JavaScript-Laufzeitumgebung basiert. Als nächstes werde ich Ihnen in diesem Artikel die Einführung in node.js vorstellen. Interessierte Freunde sollten gemeinsam einen Blick darauf werfen

Was ist NodeJS

Einfach ausgedrückt ist Node.js JavaScript, das auf der Serverseite ausgeführt wird.

Node.js ist eine Plattform, die auf der Chrome JavaScript-Laufzeitumgebung basiert.

Node.js ist eine serverseitige ereignisgesteuerte E/A-JavaScript-Umgebung, die auf der V8-Engine von Google (der vom Chrome-Browser von Google verwendeten JavaScript-Ausführungsumgebung) basiert.

Die V8-Engine wird ausgeführt Javascript Sehr schnell und sehr gute Leistung.

2. Warum NodeJS wählen

Wenn Sie ein Front-End-Programmierer sind, kennen Sie dynamische Programmiersprachen wie PHP nicht , Python oder Ruby verwenden und dann Ihren eigenen Dienst erstellen möchten, dann ist Node.js eine sehr gute Wahl.

Node.js ist JavaScript, das auf der Serverseite ausgeführt wird. Wenn Sie mit Javascript vertraut sind, werden Sie Node.js leicht erlernen.

Wenn Sie ein Back-End-Programmierer sind und einige Hochleistungsdienste bereitstellen möchten, ist das Erlernen von Node.js natürlich auch eine sehr gute Wahl.

3. Eigenschaften von NodeJS

Werfen wir zunächst einen Blick auf die Einführung auf der offiziellen NodeJS-Website:

Node .js ist eine auf der JavaScript-Laufzeitumgebung von Chrome basierende Plattform zum einfachen Erstellen schneller, skalierbarer Netzwerkanwendungen. Node.js verwendet ein ereignisgesteuertes, nicht blockierendes I/O-Modell, das es leichtgewichtig und effizient macht und sich perfekt für datenintensive Echtzeitanwendungen eignet Anwendungen, die auf verteilten Geräten ausgeführt werden.

  Seine Eigenschaften sind:

 1. Es handelt sich um eine Javascript-Laufumgebung

 2 . Hängt von der Chrome V8-Engine für die Codeinterpretation ab

 3. Ereignisgesteuert

 4. Nicht blockierende E/A

 5. Leicht, skalierbar, geeignet für echte Zeitdaten-Interaktionsanwendungen

 6. Einzelner Prozess, einzelner Thread

Asynchrones, ereignisgesteuertes Modell

Wir müssen auch eine Anfrage stellen und auf die Antwort vom Server warten. Der Unterschied zum Bankbeispiel besteht jedoch darin, dass wir nach der Bestellung des Essens eine Nummer erhalten haben 🎜>

Nachdem wir die Nummer erhalten haben, warten wir oft an unserem Standort und die Anfragen hinter uns werden weiterhin bearbeitet. Wir nehmen auch eine Nummer und warten beiseite, und die Rezeptionistin kann sie weiter bearbeiten.

Wenn das Essen bestellt wird, wird die Nummer angerufen und die anschließende Verarbeitung (Essen) durchgeführt.

Diese Aktion des Anrufs der Nummer wird in NodeJS Can genannt Führen Sie die nachfolgende Logik (Essen) weiterhin aus, nachdem das Ereignis (Kochen, E/A) abgeschlossen ist.

Dies spiegelt die bemerkenswerten Merkmale von NodeJS wider, asynchroner Mechanismus, ereignisgesteuert

Das Ganze Prozess Es besteht keine Notwendigkeit, die Verbindung neuer Benutzer (die Essen bestellen) zu blockieren, und es besteht keine Notwendigkeit, die Verbindung zwischen Benutzern, die bereits Essen bestellt haben, und dem Koch aufrechtzuerhalten.

Node.Js verwendet eine ereignisgesteuerte Funktion Modell Wenn der Webserver eine Anfrage empfängt, schließt er diese, verarbeitet sie und bedient dann die nächste Webanfrage. Wenn die Anfrage abgeschlossen ist, wird sie wieder in die Verarbeitungswarteschlange gestellt, und wenn der Kopf der Warteschlange erreicht ist, wird das Ergebnis an den Benutzer zurückgegeben. Dieses Modell ist sehr effizient und hoch skalierbar, da der Webserver immer Anfragen entgegennimmt, ohne auf Lese- oder Schreibvorgänge warten zu müssen. (Dies wird auch als nicht blockierende E/A oder ereignisgesteuerte E/A bezeichnet)

Basierend auf diesem Mechanismus kann NodeJS theoretisch auf Benutzer reagieren, die nacheinander Verbindungen anfordern, sodass NodeJS mehr als Java und PHP unterstützen kann Programme. Höhere Parallelität

Obwohl die Verwaltung der Ereigniswarteschlange auch Kosten verursacht und da NodeJS Single-Threaded ist, dauert es umso länger, bis eine Antwort eingeht, und das Ausmaß der Parallelität bleibt bestehen unzureichend

 

Um zusammenzufassen, wie NodeJS das Problem gleichzeitiger Verbindungen löst:

Ändern Sie die Art und Weise, wie eine Verbindung zum Server hergestellt wird. Jede Verbindung sendet einen Prozess aus In der NodeJS-Engine werden Ereignisse (Ereignisse), die in der Ereigniswarteschlange ausgeführt werden, in die Ereigniswarteschlange gestellt,

Anstatt für jede Verbindung einen neuen Betriebssystem-Thread zu generieren (und dafür etwas unterstützenden Speicher zuzuweisen)

E/A-Blockierung

Ein weiteres Problem, das NodeJS löst, ist die E/A-Blockierung: Sie müssen Daten aus mehreren Datenquellen abrufen und führen Sie dann die Verarbeitung aus

(1) Serielle Erfassung von Daten, dies ist unsere allgemeine Lösung, nehmen Sie PHP als Beispiel

Wenn Sie Profil- und Zeitleistenvorgänge abrufen erfordern separate Vorgänge 1S, dann erfordert die serielle Erfassung 2S

(2) NodeJS nicht blockierende E/A, die Ereignisse aussendet/abhört, um den Ausführungsprozess zu steuern

Wenn NodeJS auf ein E/A-Ereignis stößt, erstellt es einen auszuführenden Thread und führt dann den Hauptthread weiter aus.

Daher ist die Aktion von Durch die Übernahme des Profils wird ein E/A-Ereignis ausgelöst. Die Aktion zum Abrufen der Zeitleiste wird sofort ausgeführt.

Wenn jede Aktion 1S dauert, beträgt die Gesamtzeit 1S >

Ihre E/A-Vorgänge Nach Abschluss der Ausführung werden ein Ereignis, ein Profil und eine Zeitleiste ausgegeben.

Nachdem der Ereignisagent sie empfangen hat, führt er weiterhin die folgende Logik aus. Dies ist die Funktion von NodeJS nicht blockierende E/A

Zusammenfassend:

 Java und PHP haben auch Möglichkeiten, parallele Anforderungen (Sub-Threads) zu implementieren, aber NodeJS kann dies ganz natürlich über Rückruffunktionen (Callback) tun ) und asynchrone Mechanismen

4. NodeJS Vorteile und Nachteile

Vorteile:

1. Hohe Parallelität ( der wichtigste Vorteil)

2. Geeignet für I/O-intensive Anwendungen

Nachteile:

1. Nicht geeignet für CPU-intensive Anwendungen; die Hauptherausforderungen, die CPU- Intensive Anwendungen, die auf den Knoten gebracht werden, sind: Aufgrund des einzelnen JavaScript-Threads kann bei lang laufenden Berechnungen (z. B. einer großen Schleife) die CPU-Zeitscheibe nicht freigegeben werden, was dazu führt, dass nachfolgende E/A nicht freigegeben werden kann initiiert werden;

Lösung: Zerlegen Sie große Rechenaufgaben in mehrere kleine Aufgaben, damit die Rechenaufgaben rechtzeitig freigegeben werden können, ohne die Initiierung von E/A-Aufrufen zu blockieren.

2. Unterstützt nur einzelne -Core-CPU und kann die CPU nicht vollständig ausnutzen

3. Geringe Zuverlässigkeit Sobald ein bestimmter Link des Codes abstürzt, bricht das gesamte System zusammen

Grund: einzelner Prozess, einzelner Thread

Lösung: (1) Nnigx-Reverse-Proxy, Lastausgleich, mehrere Prozesse öffnen, mehrere Ports binden

(2) Mehrere Prozesse öffnen, um denselben Port abzuhören und das Cluster-Modul zu verwenden;

4. Die Qualität der Open-Source-Komponentenbibliothek ist ungleichmäßig, wird schnell aktualisiert und ist abwärtskompatibel

5. Das Debuggen ist umständlich und falsch. Kein Stack-Trace

Das obige ist der detaillierte Inhalt vonNode.js-Erste-Schritte-Tutorial. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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