Heim  >  Artikel  >  Backend-Entwicklung  >  So implementieren Sie einen Timeout-Mechanismus mit Golang

So implementieren Sie einen Timeout-Mechanismus mit Golang

PHPz
PHPzOriginal
2023-03-30 09:07:27986Durchsuche

Beim Schreiben von Netzwerkanwendungen kommt es häufig vor, dass Sie einen Timeout-Mechanismus festlegen müssen. Der Timeout-Mechanismus bezieht sich auf das Warten darauf, dass ein Vorgang innerhalb eines bestimmten Zeitraums abgeschlossen wird, z. B. auf das Warten auf eine Antwort auf eine Remote-Anfrage oder auf das Eintreten eines Ereignisses. Als effiziente Sprache bietet die Go-Sprache auch eine relativ einfache und benutzerfreundliche Implementierung des Timeout-Mechanismus. In diesem Artikel wird erläutert, wie Sie mit Golang den Timeout-Mechanismus implementieren.

Was ist der Timeout-Mechanismus?

Bevor wir den Timeout-Mechanismus verstehen, schauen wir uns zunächst an, was Blockierungsvorgänge sind. Ein blockierender Vorgang bedeutet, dass ein Vorgang aus irgendeinem Grund blockiert ist und nicht fortgesetzt werden kann. Warten Sie beispielsweise auf eine Antwort auf eine Netzwerkanforderung, warten Sie auf eine Antwort von einem E/A-Gerät usw.

Der Timeout-Mechanismus besteht darin, beim Ausführen eines Blockierungsvorgangs einen Zeitraum anzugeben. Wenn der Vorgang nicht innerhalb der angegebenen Zeit abgeschlossen wird, wird der Vorgang aktiv beendet und eine Fehlermeldung zurückgegeben. Dies hat den Vorteil, dass wir in manchen Fällen vermeiden müssen, Vorgänge zu lange zu blockieren, was zu Problemen wie einem Hängenbleiben der Benutzeroberfläche oder dem Erhalt einer Antwort durch den Client über einen längeren Zeitraum führen kann.

Golangs Timeout-Mechanismus-Implementierung

In Golang können wir den Timeout-Mechanismus über Goroutinen und Kanäle implementieren. Diese beiden Methoden werden im Folgenden vorgestellt.

Goroutine implementiert Timeout

Goroutine in der Go-Sprache entspricht einem leichten Thread, der gleichzeitige Aufgaben koordinieren kann. Wenn ein Timeout-Mechanismus benötigt wird, können wir ihn mit Goroutine implementieren.

Das Folgende ist ein Beispielcode, der Goroutine verwendet, um den Timeout-Mechanismus zu implementieren:

package main

import (
    "fmt"
    "time"
)

func main() {
    data := make(chan int)
    done := make(chan struct{})
    go func() {
        for {
            select {
            case d := <-data:
                fmt.Println("Received data:", d)
            case <-time.After(time.Second * 2):
            fmt.Println("Timeout")
            close(done)
            }
        }
    }()
    for i := 0; i < 5; i++ {
        data <- i
        time.Sleep(time.Second * 1)
    }
    <-done
    fmt.Println("Done")
}

Der obige Code verwendet Goroutine, um den Timeout-Mechanismus zu implementieren. Drucken Sie beim Empfang von Daten (d := <-data) die empfangenen Daten aus. Wenn länger als 2 Sekunden keine Daten empfangen werden, werden die Timeout-Informationen gedruckt und das Fertig-Signal (Signal) wird ausgeschaltet. Senden Sie im Hauptprogramm einige Daten an die Datenpipeline (alle 1 Sekunde) und simulieren Sie mit Sleep eine lange Blockierungszeit.

Überwachen Sie bei laufendem Programm die Daten und den Timer über die Select-Anweisung. Wenn Daten empfangen werden, springt Select heraus, wenn eine Zeitüberschreitung auftritt. Die Informationen werden gedruckt und geschlossen. Nach dem Empfang von 5 Daten schließt das Programm „Fertig“ und gibt „Fertig“ aus, um das Ende des Timeout-Mechanismus anzuzeigen.

Channel implementiert Timeout

Channel in der Go-Sprache ist eine Kommunikationsmethode, die gleichzeitige Aufgaben koordinieren kann. Bei Vorgängen, die eine Zeitüberschreitung erfordern, können wir diese auch mit Channel implementieren.

Das Folgende ist ein Beispielcode, der Channel verwendet, um den Timeout-Mechanismus zu implementieren:

package main

import (
    "fmt"
    "time"
)

func main() {
    data := make(chan int, 1)
    timeOut := make(chan bool, 1)

    go func() {
        time.Sleep(time.Second * 2)
        timeOut <- true
    }()

    select {
        case d := <-data:
            fmt.Println(d) // 接收成功
        case <-timeOut:
            fmt.Println("Receive timeout")
    }
}

Der obige Code verwendet Channel, um den Timeout-Mechanismus zu implementieren, sendet Daten an die Datenpipeline (Kapazität ist 1) und lauscht dann in der Select-Anweisung . Nach dem Lesen der Daten im Kanal kann der Druckvorgang der Daten ausgelöst werden. Und wenn es zu einer Zeitüberschreitung kommt, wird es nicht länger blockieren und warten, sondern den Timeout-Zweig auslösen.

Da die Kapazität von TimeOut und Datenpipe beide 1 beträgt, wird das Schreiben von Daten blockiert, bis ein Leser die Daten liest oder eine Zeitüberschreitung auftritt. TimeOut schreibt Daten nach zwei Sekunden Timeout und löst so einen Lesevorgang aus.

Die Methode zur Implementierung des Timeout-Mechanismus über Channel ist einfacher als bei Goroutine. Es ist jedoch zu beachten, dass die Datenpuffergröße auf 1 begrenzt sein muss, da sonst der erwartete Timeout-Effekt nicht erzielt wird.

Zusammenfassung

In diesem Artikel werden zwei Möglichkeiten vorgestellt, den Timeout-Mechanismus mithilfe von Golang zu implementieren: mithilfe von Goroutine und Channel. Beide Methoden können den Timeout-Mechanismus gut implementieren. Welche Methode ausgewählt werden soll, hängt von den tatsächlichen Anforderungen ab. Bei der Verwendung des Timeout-Mechanismus müssen wir je nach Szenario unterschiedliche Entscheidungen treffen, um die Robustheit und Sicherheit der Anwendung zu verbessern.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie einen Timeout-Mechanismus mit Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn