L'utilizzo dello snippet di codice mgo del driver MongoDB Go riportato di seguito per la connessione a MongoDB Atlas funziona, utilizzando i dati di esempio:
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)
Tieni presente che puoi anche specificare solo uno dei membri del set di repliche come seme. Ad esempio:
Addrs: []string{"prefix2.mongodb.net:27017"}
Vedi anche:
- tls.Dial()
- DialInfo
- DialWithInfo
Aggiorna :
Puoi anche usare il metodo ParseURL() per analizzare la stringa URI MongoDB Atlas. Tuttavia, attualmente questo metodo non supporta SSL (mgo.V2 PR:304)
Una soluzione consiste nell'eliminare ssl=true
riga prima dell'analisi.
//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)