私はmongodbatlasからのレプリカセットを持っており、これに他の言語と接続できます。通常のmongoクライアントには、次の形式でURLが提供されています。
"mongodb:// user:[email protected]:27017、prefix2.mongodb.net:27017、prefix3.mongodb.net:27017/test?&replicaSet = Cluster0-shard-0&authSource = admin"
何を試しても、ssl = trueを追加して削除しても、何も機能しません。常に「到達可能なサーバーがない」です。
URLのすべての組み合わせ、dialConfigのすべての組み合わせ、およびDialとDialWithConfigの構成を試しました。
理由は何でしょうか?
MongoDB Goドライバーの使用 mgo 以下のコードスニペットを使用して接続します MongoDB Atlas は、サンプルデータを使用して機能します。
import (
"gopkg.in/mgo.v2"
"crypto/tls"
"net"
)
tlsConfig := &tls.Config{}
dialInfo := &mgo.DialInfo{
Addrs: []string{"prefix1.mongodb.net:27017",
"prefix2.mongodb.net:27017",
"prefix3.mongodb.net:27017"},
Database: "authDatabaseName",
Username: "user",
Password: "pass",
}
dialInfo.DialServer = func(addr *mgo.ServerAddr) (net.Conn, error) {
conn, err := tls.Dial("tcp", addr.String(), tlsConfig)
return conn, err
}
session, err := mgo.DialWithInfo(dialInfo)
シードとして指定できるレプリカセットメンバーは1つだけであることに注意してください。例えば:
Addrs: []string{"prefix2.mongodb.net:27017"}
参照:
更新:
ParseURL() メソッドを使用してMongoDB AtlasURI文字列を解析することもできます。ただし、現在、このメソッドはSSLをサポートしていません( mgo.V2 PR:304 )
回避策は、解析する前にssl=true
行を削除することです。
//URI without ssl=true
var mongoURI = "mongodb://username:[email protected],prefix2.mongodb.net,prefix3.mongodb.net/dbName?replicaSet=replName&authSource=admin"
dialInfo, err := mgo.ParseURL(mongoURI)
//Below part is similar to above.
tlsConfig := &tls.Config{}
dialInfo.DialServer = func(addr *mgo.ServerAddr) (net.Conn, error) {
conn, err := tls.Dial("tcp", addr.String(), tlsConfig)
return conn, err
}
session, _ := mgo.DialWithInfo(dialInfo)