繁体   English   中英

Mongo-go-driver:超过上下文截止日期

[英]Mongo-go-driver: context deadline exceeded

我最近为我正在开发的应用程序升级到了更新的官方 golang mongo 驱动程序。 一切都非常适合我的本地开发,但是当我连接它并指向我的后端服务器时,我在调用 client.Ping(...) 方法时收到“超出上下文截止日期”的提示。

旧的驱动程序代码仍然可以正常工作,我还打印出连接字符串,可以将其复制并粘贴到指南针应用程序中,并且可以正常工作。

然而,对于我的生活,我无法弄清楚为什么这个新代码会返回上下文超时。 唯一不同的是 mongo 在 32680 的非标准端口上运行,我也在使用 mgm package。但是它只是使用引擎盖下的官方 mongo 驱动程序。

Mongo 版本为:4.0.12(本地和远程)

连接代码在这里:

// NewClient creates a mongo DateBase connection
func NewClient(cfg config.Mongo) (*Client, error) {
    // create database connection string
    conStr := fmt.Sprintf("mongodb://%s:%s@%s:%s", cfg.Username, cfg.Password, cfg.Host, cfg.Port)

    // set mgm conf ie ctxTimeout value
    conf := mgm.Config{CtxTimeout: cfg.CtxTimeout}

    // setup mgm / DateBase connection
    err := mgm.SetDefaultConfig(&conf, cfg.Database, options.Client().ApplyURI(conStr))
    if err != nil {
        return nil, errors.Wrapf(err, "failed to connect to mongodb. cfg: %+v. conStr: %+v.", cfg, conStr)
    }

    // get access to underlying mongodb client driver, db and mgmConfig. Need for adding additional tools like seeding/migrations/etc
    mgmCfg, client, db, err := mgm.DefaultConfigs()
    if err != nil {
        return nil, errors.Wrap(err, "failed to return mgm.DefaultConfigs")
    }

    // NOTE: fails here!
    if err := client.Ping(mgm.Ctx(), readpref.Primary()); err != nil {
        return nil, errors.Wrapf(err, "Ping failed to mongodb. cfg: %+v. conStr: %+v. mgmCfg: %+v", cfg, conStr, mgmCfg)
    }

    return &Client{
        cfg:    cfg,
        mgmCfg: mgmCfg,
        client: client,
        db:     db,
    }, nil
}

帮助? 我不知道如何再调试它?

尝试在您的 DSN 中添加您的 authsource,

就像是

mongodb://USER:PASSWORD@HOST:PORT/DBNAME?authsource=AUTHSOURCE

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM