>백엔드 개발 >Golang >MGO를 사용하여 Golang에서 '접속 가능한 서버 없음' 패닉을 방지하는 방법은 무엇입니까?

MGO를 사용하여 Golang에서 '접속 가능한 서버 없음' 패닉을 방지하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-28 15:08:111014검색

How to Prevent

MGO를 사용하는 Golang의 패닉 복구: "접근할 수 있는 서버 없음" 패닉 방지

Go에서 MGO 라이브러리를 사용하여 MongoDB 인스턴스에 연결할 때 , 인스턴스를 사용할 수 없거나 오프라인인 경우 "접근할 수 있는 서버 없음" 패닉이 발생할 수 있습니다. 이로 인해 예기치 않은 프로그램 종료가 발생할 수 있습니다.

이 문제를 방지하기 위해 Go의 지연 및 복구 기능을 사용하여 복구 메커니즘을 구현할 수 있습니다. 그러나 해당 질문에 제공된 솔루션이 효과적으로 작동하지 않습니다.

수정된 코드:

아래는 패닉 상태에서 성공적으로 복구된 주어진 코드의 수정된 버전입니다. 프로그램이 계속 실행되도록 허용합니다.

package main

import (
    "fmt"
    "time"
)

import (
    "labix.org/v2/mgo"
)

func connectToMongo() bool {
    fmt.Println("enter main - connecting to mongo")
    defer func() {
        if r := recover(); r != nil {
            fmt.Println("Unable to connect to MongoDB. Received panic:", r)
        }
    }()

    maxWait := time.Duration(5 * time.Second)
    session, err := mgo.DialWithTimeout("localhost:27017", maxWait)
    if err != nil {
        return false
    }

    session.SetMode(mgo.Monotonic, true)
    coll := session.DB("MyDB").C("MyCollection")

    if coll != nil {
        fmt.Println("Got a collection object")
        return true
    }

    fmt.Println("Unable to retrieve collection")
    return false
}

func main() {
    if connectToMongo() {
        fmt.Println("Connected")
    } else {
        fmt.Println("Not Connected")
    }
}

이 코드에서는 지연 함수를 사용하여 다음으로 인한 패닉을 포착합니다. DialWithTimeout 호출. 패닉이 발생하면 오류 메시지를 인쇄하고 프로그램 실행을 계속하여 조기 종료를 방지합니다.

MongoDB가 다운된 경우 출력:

MongoDB가 다운된 경우, 프로그램은 다음과 같은 출력을 생성합니다.

enter main - connecting to mongo
Unable to connect to MongoDB. Received panic: no reachable servers
Not Connected

MongoDB를 사용한 출력 Up:

MongoDB가 실행되면 프로그램은 다음과 같은 출력을 생성합니다.

enter main - connecting to mongo
Got a collection object
Connected

패닉을 포착하고 유익한 오류 메시지를 제공함으로써 프로그램이 계속되도록 보장할 수 있습니다. 일시적인 네트워크 문제나 MongoDB 중단을 원활하게 처리할 수 있습니다.

위 내용은 MGO를 사용하여 Golang에서 '접속 가능한 서버 없음' 패닉을 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.