【问题标题】:Golang and MongoDb remote access fail (server returned error on SASL authentication step: Authentication failed.)Golang 和 MongoDb 远程访问失败(服务器在 SASL 身份验证步骤返回错误:身份验证失败。)
【发布时间】:2016-06-08 16:46:42
【问题描述】:

我正在尝试使用 mgo 库从 Go 连接到远程 MongoDB 数据库 (Mongolab),但出现错误 panic: server returned error on SASL authentication step: Authentication failed。这是我的代码

package main

import (
    "fmt"
    "gopkg.in/mgo.v2"
    "gopkg.in/mgo.v2/bson"
    "log"
)

type Person struct {
    Name  string
    Phone string
}

func main() {
    session, err := mgo.Dial("mongodb://<dbusername>:<dbpassword>@ds055855.mlab.com:55855")

    if err != nil {
        panic(err)
    }
    defer session.Close()

    // Optional. Switch the session to a monotonic behavior.
    session.SetMode(mgo.Monotonic, true)

    c := session.DB("catalog").C("History")
    err = c.Insert(&Person{"Ale", "+55 53 8116 9639"},
        &Person{"Cla", "+55 53 8402 8510"})
    if err != nil {
        log.Fatal(err)
    }

    result := Person{}
    err = c.Find(bson.M{"name": "Ale"}).One(&result)
    if err != nil {
        log.Fatal(err)
    }

    fmt.Println("Phone:", result.Phone)
}

我该如何解决这个问题?当然,我写的是我的登录名和密码,而不是我的代码中的星号。

【问题讨论】:

    标签: mongodb authentication go remote-access mlab


    【解决方案1】:

    请检查您是否为 Mongolab 数据库实例添加了用户(https://mongolab.com/databases/catalog#users,如果您的数据库名称为 catalog),因为默认情况下您的用户列表为空(帐户用户/密码!= 数据库用户/密码) .

    还将/&lt;databasename&gt; 添加到连接字符串的末尾 - mongodb://*******:*******@ds045795.mongolab.com:45795/databasename

    【讨论】:

    • 我试过你的答案(添加用户数据库,添加数据库名称到连接),但什么也没发生:(
    • @ВладДарьев 这是不可能的。试试这个连接字符串mongodb://souser:123456@ds055855.mlab.com:55855/catalog
    • 同样的错误:(session, err := mgo.Dial("mongodb://souser:123456@ds055855.mlab.com:55855/catalog") panic:服务器在 SASL 身份验证步骤返回错误:身份验证失败。
    • @ВладДарьев 我不确定您的问题是否可重复。这是您的代码执行的结果i.imgur.com/ucc42Vm.png 如您所见,没有添加或更改任何内容(连接字符串除外)并且它有效。您可以使用 RoboMongo 等工具连接到您的 Mongolab 实例吗?
    • 是的...很好。我发现了多余的代码字符串,但问题不存在,我认为您关于为数据库创建用户的建议是解决方案。非常感谢!)
    猜你喜欢
    • 2019-12-17
    • 1970-01-01
    • 2016-11-26
    • 2018-06-05
    • 2017-04-08
    • 1970-01-01
    • 2016-08-20
    • 1970-01-01
    • 2016-01-17
    相关资源
    最近更新 更多