mongodb - 通过 ssl 将 golang mgo 连接到 mongo

标签 mongodb ssl go tls1.2 compose-db

我正在尝试在本地设置 mongo 以测试

中描述的设置

https://www.compose.com/articles/connect-to-mongo-3-2-on-compose-from-golang/ “有点难”部分

蒙戈

我有一组有效的自签名凭据和 mongo 设置。 我包含了 key ,因为这些 key 只会在开发期间使用,以确保 mongo ssl 代码正常工作。

mongo ssl config

使用时,通过

运行
mongod --config config/location

配置是

net:
  port: 27017
  ssl:
    mode: requireSSL
    CAFile: /data/mongo/ca.crt
    PEMKeyFile: /data/mongo/server.pem
    allowInvalidHostnames: true
    allowConnectionsWithoutCertificates: true

然后我可以连接到数据库

mongo --ssl --sslCAFile /data/mongo/ca.crt

戈兰

func NewSession(url string, ca string) (m *mgo.Session, err error) {
    roots := x509.NewCertPool()
    roots.AppendCertsFromPEM([]byte(ca))

    tlsConfig := &tls.Config{}
    tlsConfig.RootCAs = roots

    url = strings.TrimSuffix(url, "?ssl=true")
    dialInfo, err := mgo.ParseURL(url)
    dialInfo.DialServer = func(addr *mgo.ServerAddr) (net.Conn, error) {
        conn, err := tls.Dial("tcp", addr.String(), tlsConfig)
        return conn, err
    }

    //Here it is the session. Up to you from here ;)
    session, err := mgo.DialWithInfo(dialInfo)
    if err != nil {
        return m, err
    }

    session.SetMode(mgo.Monotonic, true)

    return session, nil
}

结果

golang 东西尝试连接并达到 10 秒超时。 session 顶部的 fmt 显示正确的文件正在进入 ca var。

Mongo日志展示

utumongo_1         | 2017-07-27T08:09:14.964+0000 I NETWORK  [initandlisten] connection accepted from 172.19.0.4:57474 #30 (1 connection now open)
utumongo_1         | 2017-07-27T08:09:14.966+0000 E NETWORK  [conn30] SSL: error:14094412:SSL routines:SSL3_READ_BYTES:sslv3 alert bad certificate
utumongo_1         | 2017-07-27T08:09:14.967+0000 I NETWORK  [conn30] end connection 172.19.0.4:57474 (0 connections now open)

编辑 更新了 mongo 配置

最佳答案

您要将什么作为 ca 参数传递给 NewSession?这需要是 PEM 编码的 CA 证书字节,而不是 CA 证书的文件名。 AppendCertsFromPEM 将返回 true 如果它设法将任何证书添加到池中。

文章已经显示了执行此操作的代码:

if ca, err := ioutil.ReadFile("myPEM"); err == nil { 
    roots.AppendCertsFromPEM(ca)
}

SSL 错误意味着客户端拒绝服务器证书。我怀疑这是因为您的自签名证书未正确添加到池中。

编辑

我使用您的配置在本地运行了一个 mongo 副本。使用 docker,这是:

docker run --rm -ti -v $(pwd):/data/mongo --net=host mongo -f /data/mongo/mongo.yaml

从提取配置的位置运行时

根据我的评论,在 Go 中使用你的 NewSession 函数显示 tls.Dial 由于缺少任何主题访问名称 (SAN) 扩展而返回错误下面。

您需要更正您的服务器证书以具有所需的适当主机名(或 IP 地址)SAN 条目。

您可以调试此错误以及发生在以下情况的任何其他 TLS 连接错误:

dialInfo.DialServer = func(addr *mgo.ServerAddr) (net.Conn, error) {
    conn, err := tls.Dial("tcp", addr.String(), tlsConfig)
    if err != nil {
        fmt.Println(err)
    }
    return conn, err
}

关于mongodb - 通过 ssl 将 golang mgo 连接到 mongo,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45345006/

相关文章:

go - 如何仅使用 4 位来表示 Go 中的数字?

javascript - MongoDB Node.js 驱动程序 : callback does not handle exceptions on insert

wordpress - htaccess 需要重定向主域而不是附加域

mongodb - 由于 DataDog/zstd,Gcloud 应用程序部署因 mongo-driver 失败

security - 具有有限客户端的自签名证书

ssl - Nginx/php-fpm开启HTTPS后无法执行PHP文件

go - 如何理解golang内存模型中的channel通信规则?

elasticsearch - 如何检查 ElasticSearch BulkProcessor 服务是否存在

node.js - 嵌套在具有相同键聚合的嵌套对象中,与 mongoDB 中的另一个集合

mongodb - Elasticsearch-更新非索引字段