Heim >Web-Frontend >js-Tutorial >Wie aktiviere ich das NodeJS-Debugging? Wie debugge ich das NodeJS-Programm?

Wie aktiviere ich das NodeJS-Debugging? Wie debugge ich das NodeJS-Programm?

青灯夜游
青灯夜游nach vorne
2022-01-20 19:55:035227Durchsuche

Wie debugge ich ein nodejs-Programm? Der folgende Artikel stellt Ihnen die Debugging-Methode von nodejs vor. Ich hoffe, er wird Ihnen hilfreich sein!

Wie aktiviere ich das NodeJS-Debugging? Wie debugge ich das NodeJS-Programm?

Entwickler müssen bei der Entwicklung von Anwendungen häufig auf die Debugging-Funktion der Programmiersprache zurückgreifen, um die Entwicklung zu vereinfachen und Fehler zu beheben. Im Allgemeinen müssen wir die Debugging-Funktion einer leistungsstarken IDE verwenden, um diese Arbeit abzuschließen. nodejs ist keine Ausnahme.

Heute werden wir im Detail vorstellen, wie man das node-Programm debuggt.

NodeJS-Debugging aktivieren

Erinnern Sie sich noch an das Koa-Programm, über das wir zuvor gesprochen haben? In diesem Artikel wird ein einfaches Koa-Serverprogramm als Beispiel verwendet, um mit dem Debuggen von NodeJS zu beginnen.

Werfen wir zunächst einen Blick auf einen einfachen Koa-Dienst app.js:

const Koa = require('koa');
const app = module.exports = new Koa();

app.use(async function(ctx) {
  ctx.body = 'Hello World';
});

if (!module.parent) app.listen(3000);

Das obige Programm öffnet Port 3000 und richtet einen http-Dienst ein. Bei jeder Anfrage wird „hello World“ zurückgegeben, was sehr einfach ist.

Um das obige Programm auszuführen, müssen wir node app.js ausführen. Dadurch wird app.js ausgeführt, das Debuggen wird jedoch nicht aktiviert.

Wie debugge ich?

Wir müssen den Parameter --inspect hinzufügen:

node --inspect app.js

Der obige Code aktiviert die Debugging-Funktion von nodejs.

Werfen wir einen Blick auf die Ausgabe:

Debugger listening on ws://127.0.0.1:9229/88c23ae3-9081-41cd-98b0-d0f7ebceab5a
For help, see: https://nodejs.org/en/docs/inspector

Die Ergebnisse sagen uns zwei Dinge. Das erste ist der Port, den der Debugger abhört. Standardmäßig wird Port 9229 von 127.0.0.1 geöffnet. Und zur Unterscheidung eine eindeutige UUID zugewiesen.

Das zweite ist, uns mitzuteilen, dass der von nodejs verwendete Debugger Inspector ist.

Inspector wurde nach NodeJS 8 eingeführt. Wenn es vor NodeJS 7 ist, wird der Legacy-Debugger verwendet.

Sicherheit beim Debuggen

Wenn der Debugger mit der NodeJS-Laufumgebung verbunden ist und ein böswilliger Angreifer vorhanden ist, kann der böswillige Angreifer beliebigen Code in der NodeJS-Umgebung ausführen. Dies birgt große Sicherheitsrisiken für unser Programm.

Wir müssen also auf die Sicherheit des Debuggens achten. Im Allgemeinen empfehlen wir kein Remote-Debugging.

Standardmäßig ist --inspect an 127.0.0.1 gebunden, was nur lokalen Programmen den Zugriff ermöglicht. Und jedes lokal laufende Programm hat die Berechtigung, das Programm zu debuggen.

Wenn wir das Debug-Programm wirklich externen Programmen zugänglich machen möchten, können wir die externe IP-Adresse des Computers oder 0.0.0.0 (d. h. eine beliebige Adresse, keine Einschränkungen) angeben, damit der Remote-Computer Remote-Debugging durchführen kann.

Was sollten wir tun, wenn wir ein sicheres Remote-Debugging durchführen möchten?

Zuerst müssen wir das lokale Debugging aktivieren:

node --inspect app.js

Dann können wir einen SSH-Tunnel erstellen, um den lokalen 9221-Port dem 9229-Port des Remote-Servers zuzuordnen:

ssh -L 9221:localhost:9229 user@remote.example.com

Auf diese Weise können wir uns mit dem lokalen 9221 verbinden Port. Remote-Debugging.

Verwenden Sie WebStorm zum Debuggen von NodeJS. Man kann sagen, dass WebStorm von JetBrains ein leistungsstarkes Tool für die Entwicklung von NodeJS ist. Wenn Sie diese Option aktivieren, wird sie im Hintergrund aktiviert :

Die Verwendung von WebStorm Debugging ähnelt der Verwendung von IDEA zum Debuggen von Java-Programmen, daher werde ich hier nicht auf Details eingehen.

Verwenden Sie Chrome devTools zum Debuggen

Die Voraussetzung für die Verwendung von Chrome devTools zum Debuggen ist, dass wir den --inspect-Modus aktiviert haben.

Geben Sie chrome://inspect in Chrome ein:

Wir können die Chrome-Inspect-Schnittstelle sehen. Wenn Sie bereits ein NodeJS-Programm mit lokal aktiviertem Inspect haben, können Sie es direkt in Remote Target sehen.

Wählen Sie das Ziel aus, das Sie debuggen möchten, und klicken Sie auf „Inspizieren“, um das Chrome devTools-Debugging-Tool zu öffnen:

Sie können das Programm profilieren und debuggen.

Hier konzentrieren wir uns auf das Debuggen. Gehen Sie also zur Quellspalte und fügen Sie den Quellcode des Programms hinzu, das Sie debuggen möchten:

Fügen Sie Haltepunkte hinzu, um mit dem Debuggen zu beginnen. Es ist dasselbe wie das Debuggen von js auf der Webseite in Chrome.

Verwenden Sie Node-Inspect zum Debuggen

Tatsächlich verfügt NodeJS über ein integriertes Debugging-Tool namens Node-Inspect, bei dem es sich um ein CLI-Debugging-Tool handelt. Mal sehen, wie man es benutzt.

Wir verwenden direkt:

node inspect app.js

< Debugger listening on ws://127.0.0.1:9229/f1c64736-47a1-42c9-9e9e-f2665073d3eb
< For help, see: https://nodejs.org/en/docs/inspector
< Debugger attached.
Break on start in app.js:1
> 1 const Koa = require(&#39;koa&#39;);
  2 const app = module.exports = new Koa();
  3 
debug>

node inspect, um zwei Dinge zu tun. Das erste ist, eine Unterroutine zum Ausführen von node --inspect app.js zu generieren, und das zweite ist, das CLI-Debugging-Fenster im Hauptprogramm auszuführen.

Dieser CLI-Debugger stellt uns einige sehr nützliche Befehle zur Verfügung:

1, Stepping

cont, c: Ausführung fortsetzen

    next, n: Schritt zum nächsten Schritt
  • step, s: Step in
  • out, o: Aussteigen
  • pause: Laufenden Code anhalten
  • 2, Haltepunkte

  • setBreakpoint(), sb(): Setzt einen Haltepunkt in der aktuellen Zeile
  • setBreakpoint(line), sb(line): Setzt einen Haltepunkt in der angegebenen Zeile
  • setBreakpoint('fn()'), sb(… ) : Setze einen Haltepunkt in der angegebenen Funktion
  • setBreakpoint('script.js', 1), sb(...): Setze einen Haltepunkt in der angegebenen Skriptdatei
  • clearBreakpoint('script.js', 1), cb (...): Haltepunkte aus der Datei löschen

3, Information

  • backtrace, bt: Backtrace-Informationen des aktuellen Ausführungsrahmens drucken
  • list(5): Listen Sie die 5 Zeilen davor und danach auf der Quellcode
  • watch (expr): Watch-Ausdruck hinzufügen
  • unwatch(expr): Watch-Ausdruck löschen
  • watchers: Alle Watcher auflisten
  • repl: Repl-Ausdruck öffnen
  • exec expr: Ausdruck

über die oben genannten Schritte ausführen Mit dem Befehl können wir komplexere Debugging-Aktivitäten in der CLI durchführen.

Andere Debug-Clients

Zusätzlich zu den oben genannten können wir auch vscode, Visual Studio, Eclipse IDE usw. zum Debuggen von NodeJS verwenden, was hier nicht im Detail vorgestellt wird.

Interessierte Freunde können auf eigene Faust erkunden.

Weitere Informationen zu Knoten finden Sie unter: nodejs-Tutorial! !

Das obige ist der detaillierte Inhalt vonWie aktiviere ich das NodeJS-Debugging? Wie debugge ich das NodeJS-Programm?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen