Usar el fragmento de código mgo del controlador MongoDB Go a continuación para conectarse a MongoDB Atlas funciona, usando sus datos de ejemplo:
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)
Tenga en cuenta que también puede especificar solo uno de los miembros del conjunto de réplicas como semilla. Por ejemplo:
Addrs: []string{"prefix2.mongodb.net:27017"}
Véase también:
- tls.Dial()
- Información de marcación
- Marcar con información
Actualizar :
También puede usar el método ParseURL() para analizar la cadena URI de MongoDB Atlas. Sin embargo, actualmente este método no es compatible con SSL (mgo.V2 PR:304)
Una solución es sacar el ssl=true
línea antes de analizar.
//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)