Heim  >  Artikel  >  Web-Frontend  >  Erfahren Sie mehr über das Debuggen von NodeJS-Programmen

Erfahren Sie mehr über das Debuggen von NodeJS-Programmen

青灯夜游
青灯夜游nach vorne
2021-05-24 10:44:222227Durchsuche

Erfahren Sie mehr über das Debuggen von NodeJS-Programmen

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 ausführlich vorstellen, wie man NodeJS-Programme 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. [Empfohlenes Lernen: „nodejs-Tutorial“]

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 des Debuggens

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 zum Debuggen ä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

2eeb910a2be79e2227cae7c992736c7b 1 const Koa = require('koa');
  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: Step out
  • Pause: Den laufenden Code anhalten
  1. Haltepunkte
  • setBreakpoint(), sb(): Setzt einen Haltepunkt in der aktuellen Zeile
  • setBreakpoint(line), sb(line): Setzt einen Haltepunkt in der angegebenen Zeile
  • setBreakpoint('fn()' ), sb(...): Setzt einen Haltepunkt in der angegebenen Funktion
  • setBreakpoint('script.js', 1), sb(...): Setzt einen Haltepunkt in der angegebenen Skriptdatei
  • clearBreakpoint('script .js', 1), cb(…): Haltepunkte aus der Datei löschen vor und nach dem Quellcode
watch(expr): Watch-Ausdruck hinzufügen
  1. unwatch(expr): Watch-Ausdruck löschen
watchers: alle Watcher auflisten
  • repl: Repl-Ausdruck öffnen
  • exec expr: Ausdruck ausführen
  • Durch Mit dem obigen 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.
Autor dieses Artikels: Diese Dinge über das Flydean-Programm

Link zu diesem Artikel: http://www.flydean.com/nodejs-debug/

Quelle dieses Artikels: Flydeans Blog

Für mehr Programmierung- Verwandte Kenntnisse finden Sie unter:

Einführung in die Programmierung
! !

Das obige ist der detaillierte Inhalt vonErfahren Sie mehr über das Debuggen von NodeJS-Programmen. 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