Att använda MongoDB Go-drivrutinen mgo-kodavsnittet nedan för att ansluta till MongoDB Atlas fungerar, med hjälp av dina exempeldata:
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)
Observera att du också kan ange endast en av replikuppsättningsmedlemmarna som ett frö. Till exempel:
Addrs: []string{"prefix2.mongodb.net:27017"}
Se även:
- tls.Dial()
- DialInfo
- DialWithInfo
Uppdatera :
Du kan också använda metoden ParseURL() för att analysera MongoDB Atlas URI-sträng. Men för närvarande stöder denna metod inte SSL (mgo.V2 PR:304)
En lösning är att ta ut ssl=true
rad före analys.
//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)