Golang-Debugging-Schnittstelle geschlossen
Ich bin kürzlich in meinem Projekt auf ein seltsames Problem gestoßen, das heißt, wenn ich Golang zum Debuggen der Schnittstelle verwende, wird die Schnittstelle nach einer gewissen Zeit automatisch geschlossen. Dies bereitet uns große Unannehmlichkeiten, da wir die Schnittstelle ständig neu starten müssen, um mit dem Debuggen fortzufahren. In diesem Artikel werde ich meine Lösung teilen.
Zunächst habe ich das http-Paket in der Standardbibliothek in Golang verfolgt und festgestellt, dass im Wesentlichen der Typ http.Server die Basis aller HTTP-Server ist. Ich habe versucht, diesen Typ zum Starten meines HTTP-Servers zu verwenden, und habe das Problem mit tiefem Debugging-Verständnis gelöst. Dabei habe ich etwas Interessantes entdeckt.
Bevor http.Server mit der Verarbeitung der Anfrage beginnt, verwendet er net.Listen, um einen Verweis auf den HTTP-Listener zu speichern. Anschließend können Sie durch Instanziieren des HTTP-Listeners damit beginnen, neue HTTP-Anfragen anzunehmen. Das sieht wie folgt aus:
l, err := net.Listen("tcp", ":8080")
if err != nil {
log.Fatal(err)
}
s := &http.Server{}
// Mit der Verarbeitung von Anfragen beginnen
s.Serve(l)
Nachdem ich das wusste, habe ich mich an einige Bibliotheken von Drittanbietern gewandt, um deren Code-Implementierung zu sehen. Wir haben einige Bibliotheken wie Gorilla Mux verwendet und festgestellt, dass sie nicht die oben beschriebene Methode zum Erstellen von HTTP-Diensten verwenden, sondern die Funktion http.ListenAndServe (ich denke, das wird von vielen Leuten verwendet) wie folgt verwenden:
http.ListenAndServe (" :8080", nil)
Der zweite Parameter ist die von uns geschriebene Route-Handler-Funktion (oder jeder andere Typ, der die Handler-Schnittstelle implementiert).
http.ListenAndServe funktioniert ähnlich wie wir einen HTTP-Listener über net.Listen initialisieren und ihn über http.Server.Serve starten. Es ist jedoch einfacher und kann in einem Rutsch durchgeführt werden.
Als ich das ausgetauscht habe, hat alles wieder gut funktioniert. Die Schnittstelle schließt nicht automatisch, ich kann Haltepunkte im Code setzen, neu laden oder auf die Schnittstelle zugreifen, da sie immer auf dem Port lauscht. Eigentlich denke ich, dass http.ListenAndServe als normale HTTP-Server-Startmethode verwendet werden sollte.
Zusammenfassend lässt sich sagen, dass es sich bei der Verwendung von Golang empfiehlt, die Funktion http.ListenAndServe zum Starten des HTTP-Servers zu verwenden. Dies kann eine effektive Lösung sein. Ich hoffe, dass Ihnen ein umfassendes Verständnis der Golang-Standardbibliothek und der Bibliotheken von Drittanbietern dabei helfen kann, die Funktionsweise von Golang besser zu verstehen.
Das obige ist der detaillierte Inhalt vonGolang-Debugging-Schnittstelle geschlossen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Dieser Artikel erläutert die Paketimportmechanismen von Go: benannte Importe (z. B. importieren & quot; fmt & quot;) und leere Importe (z. B. Import _ & quot; fmt & quot;). Benannte Importe machen Paketinhalte zugänglich, während leere Importe nur T ausführen

In diesem Artikel werden die Newflash () -Funktion von BeEGO für die Übertragung zwischen PAGE in Webanwendungen erläutert. Es konzentriert sich auf die Verwendung von Newflash (), um temporäre Nachrichten (Erfolg, Fehler, Warnung) zwischen den Controllern anzuzeigen und den Sitzungsmechanismus zu nutzen. Limita

Dieser Artikel beschreibt die effiziente Konvertierung von MySQL -Abfrageergebnissen in GO -Strukturscheiben. Es wird unter Verwendung der SCAN -Methode von Datenbank/SQL zur optimalen Leistung hervorgehoben, wobei die manuelle Parsen vermieden wird. Best Practices für die Struktur -Feldzuordnung mithilfe von DB -Tags und Robus

Dieser Artikel zeigt, dass Mocks und Stubs in GO für Unit -Tests erstellen. Es betont die Verwendung von Schnittstellen, liefert Beispiele für Mock -Implementierungen und diskutiert Best Practices wie die Fokussierung von Mocks und die Verwendung von Assertion -Bibliotheken. Die Articl

In diesem Artikel werden die benutzerdefinierten Typ -Einschränkungen von GO für Generika untersucht. Es wird beschrieben, wie Schnittstellen die minimalen Typanforderungen für generische Funktionen definieren und die Sicherheitstypsicherheit und die Wiederverwendbarkeit von Code verbessern. Der Artikel erörtert auch Einschränkungen und Best Practices

Dieser Artikel beschreibt effizientes Dateischreiben in Go und vergleicht OS.WriteFile (geeignet für kleine Dateien) mit OS.openfile und gepufferter Schreibvorgänge (optimal für große Dateien). Es betont eine robuste Fehlerbehandlung, die Verwendung von Aufschub und Überprüfung auf bestimmte Fehler.

In dem Artikel werden Schreiben von Unit -Tests in GO erörtert, die Best Practices, Spottechniken und Tools für ein effizientes Testmanagement abdecken.

In diesem Artikel wird die Verwendung von Tracing -Tools zur Analyse von GO -Anwendungsausführungsfluss untersucht. Es werden manuelle und automatische Instrumentierungstechniken, den Vergleich von Tools wie Jaeger, Zipkin und Opentelemetrie erörtert und die effektive Datenvisualisierung hervorheben
