Heim  >  Artikel  >  Backend-Entwicklung  >  Gehen Sie zu http.ListenAndServe, ohne auf die Verbindung zu warten. Es sieht aus wie ein Beenden

Gehen Sie zu http.ListenAndServe, ohne auf die Verbindung zu warten. Es sieht aus wie ein Beenden

WBOY
WBOYnach vorne
2024-02-14 22:12:08874Durchsuche

go http.ListenAndServe 不等待连接看起来像是退出

php-Editor Yuzi stellt Ihnen in diesem Artikel ein interessantes und häufiges Problem vor, nämlich den Grund, warum die Funktion http.ListenAndServe in der Go-Sprache scheinbar beendet wird, ohne auf die Verbindung zu warten. Diese Frage mag verwirrend sein, sie wird jedoch tatsächlich durch die Parallelitätseigenschaften der Go-Sprache verursacht. Im folgenden Inhalt erklären wir die Ursache dieses Problems im Detail und geben Lösungen, die den Lesern helfen, die http.ListenAndServe-Funktion in der Go-Sprache besser zu verstehen und zu verwenden.

Frageninhalt

Ich habe eine einfache Anwendung und möchte, dass es sich um einen Daemon handelt, der auf Verbindungen wartet, aber es sieht so aus, als würde er nicht zuhören und ich kann ihn nicht einmal in der Prozessliste finden.

Code:

package main

import (
        "fmt"
        "log"
        "net/http"
)

func main() {
        fmt.Println("Start Server")
        log.Print("Start Server")
        http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
                fmt.Fprintln(w, "Hello, World! from linux")
        })
        log.Print("Going to listen")
        if err := http.ListenAndServe(":80", nil); err != err {
          log.Print("getting error")
          log.Fatal(err)
        }
        fmt.Println("End  Server")
        log.Print("End  Server")
}

Kompilieren und ausführen:

xxx@xxx:~/go_test$ CGO_ENABLED=0 go build -gcflags "all=-N -l" -o ./main
    umen@umen:~/go_test$ ./main
Start Server
2023/11/15 07:40:22 Start Server
2023/11/15 07:40:22 Going to listen
End  Server
2023/11/15 07:40:22 End  Server

Versuchen Sie, eine Verbindung herzustellen:

xxx@xxx:~$ curl http://localhost
curl: (7) Failed to connect to localhost port 80 after 0 ms: Connection refused

Was fehlt mir hier?

Update

Fatal wurde entfernt, das immer noch startet und stoppt, ohne auf Get-Anfragen zu warten.

Workaround

log.Fatal("Going to Listen") Beenden Sie die Ausführung Ihrer Anwendung.

Referenz:

Das obige ist der detaillierte Inhalt vonGehen Sie zu http.ListenAndServe, ohne auf die Verbindung zu warten. Es sieht aus wie ein Beenden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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