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 unzureichendUm 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 steuernWenn 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 Mechanismen4. NodeJS Vorteile und Nachteile
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!