Heim >Backend-Entwicklung >Golang >Wie gehe ich mit Panik beim MGO DialWithTimeout()-Fehler von Go um?
Stellen Sie sich die folgende Situation vor: Sie haben eine Go-Funktion, die über die MGO-Bibliothek eine Verbindung zu einer MongoDB-Instanz herstellt. Sie möchten jedoch den Fall bewältigen, dass MongoDB nicht verfügbar ist, ohne dass das Programm abstürzt.
Der ursprüngliche Code versucht, dies durch die Verwendung eines Verzögerungs-/Wiederherstellungsmechanismus zu erreichen. Die Panik führt jedoch immer noch dazu, dass das Programm beendet wird. Lassen Sie uns einen überarbeiteten Ansatz erkunden:
package main import ( "fmt" "time" ) import ( "labix.org/v2/mgo" ) func connectToMongo() bool { ret := false fmt.Println("enter main - connecting to mongo") // Handle panic defer func() { if r := recover(); r != nil { fmt.Println("Detected panic") var ok bool err, ok := r.(error) if !ok { fmt.Printf("pkg: %v, error: %s", r, err) } } }() maxWait := time.Duration(5 * time.Second) session, sessionErr := mgo.DialWithTimeout("localhost:27017", maxWait) if sessionErr == nil { session.SetMode(mgo.Monotonic, true) coll := session.DB("MyDB").C("MyCollection") if (coll != nil) { fmt.Println("Got a collection object") ret = true } } else { // never gets here fmt.Println("Unable to connect to local mongo instance!") } return ret } func main() { if (connectToMongo()) { fmt.Println("Connected") } else { fmt.Println("Not Connected") } }
In diesem überarbeiteten Code:
Durch die Implementierung dieses Fehlerbehandlungsmechanismus können Sie die Situation, in der MongoDB vorhanden ist, elegant bewältigen ist nicht verfügbar, ohne dass Ihr Programm abstürzt. Dadurch kann Ihre Anwendung weiterhin andere Aufgaben verarbeiten oder mit einer beschreibenden Fehlermeldung ordnungsgemäß fehlschlagen.
Das obige ist der detaillierte Inhalt vonWie gehe ich mit Panik beim MGO DialWithTimeout()-Fehler von Go um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!