
文章插图
通常我们的数据库都配置为内网访问 , 但由于业务部署架构的不同 , 有时也需要通过公网访问 MongoDB 数据库 , 此时为了防止被端口扫描和脱库 , MongoDB 需要配置为 TLS 访问 , 那在 Go 中应该如何实现呢?
依赖
- 配置了 TLS 公网访问的 MongoDB 实例
- Go 的 MongoDB 驱动 globalsign/mgo
Go 实现代码:package modelimport ( "crypto/tls" "crypto/x509" "errors" "github.com/globalsign/mgo" "io/ioutil" "log" "net")func main() { dsn := "mongodb://user:password@host/database" dialInfo, err := mgo.ParseURL(dsn) if err != nil {log.Panic(err) } // read pemfile data pemData, err := ioutil.ReadFile("./pemfile") if err != nil {log.Panic(err) } roots := x509.NewCertPool() if !roots.AppendCertsFromPEM(pemData) {log.Panic(errors.New("failed to parse root certificate")) } // set tls config tlsConfig := &tls.Config{RootCAs: roots,InsecureSkipVerify: true, } // update dialserver with tls Dial dialInfo.DialServer = func(addr *mgo.ServerAddr) (net.Conn, error) {conn, err := tls.Dial("tcp", addr.String(), tlsConfig)if err != nil {log.Println(err)}return conn, err } session, err := mgo.DialWithInfo(dialInfo) if err != nil {log.Panic(err.Error()) } // db operation with session}通过以上代码 , 我们就能通过公网连接 tls 的 MongoDB 实例 , 当连接上后 , 其数据库的操作和内网连接一致 。
【如何在 Go 中使用 TLS 连接 MongoDB】
推荐阅读
-
-
-
暴雨|17号台风“狮子山”即将登陆:华南地区将迎来大范围降雨
-
-
-
-
6000mAh长续航小钢炮,联想乐檬K12 Pro手机初体验
-
-
巨蟹座|巨蟹座交往的5大禁忌,即使再爱你,也没办法包容你这样做
-
情感|她是孔家最受宠的女儿,为了爱情家穷书生,最后却是如此结局!
-
-
梦寒说时尚36岁桂纶镁仍秀身材,反倒是景甜很保守,40岁董洁敢穿流苏裙
-
-
物理|“3+1+2”新高考模式下,考生不选这一科目,会失去很多机会
-
小艾汽车|经常清理这个孔是关键,男司机:越开越有劲了!,不管汽车多少钱
-
土行孙@圣人之下,孔宣谁都不怕,却唯独怕这位凡人,曾打得孔宣落荒而逃
-
-
-
吴邪和解雨臣在秦岭神树就认识了为什么到终极笔记又不认识了?
-