MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Golang / MGO -- pânico:nenhum servidor acessível


Execute a seguinte versão do código postado. Tente não modificar o código, pelo menos não alterando a posição dos números de linha. Dessa forma, se você postar um stacktrace, os números serão correspondentes.
package main

import (
    "fmt"
    "time"
)

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

func connectToMongo() bool {
    ret := false
    fmt.Println("enter main - connecting to mongo")

    // tried doing this - doesn't work as intended
    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")
    }
}

Quando o MongoDB está ativo, vejo:
enter main - connecting to mongo
Got a collection object
Connected

Quando o MongoDB está inativo, vejo:
enter main - connecting to mongo
Unable to connect to local mongo instance!
Not Connected

Se você não vir o mesmo comportamento, poste a saída, incluindo o pânico que você vê.