5

我正在编写一个基本的谷歌云函数,它将从 MongoDB Atlas 查询一个 MongoDB 集群。我在 Google 控制台中编写,并且确定将 "mongodb": "^3.0.2" 添加到 package.json 文件中的依赖项中。

这是功能(为了安全起见,我在uri中替换了有效密码等):

/**
* Responds to any HTTP request that can provide a "message" field in the 
body.
 *
 * @param {!Object} req Cloud Function request context.
 * @param {!Object} res Cloud Function response context.
 */
exports.myPackage = (req, res) => {    
  var MongoClient = require('mongodb').MongoClient;
  var uri = "mongodb+srv://<USERNAME>:<PASSWORD>@<CLUSTER-NAME>-vtbhs.mongodb.net/test";
  MongoClient.connect(uri, function(err, client) {
    if (err) {
      console.log('err');
      console.log(err);
    } else {
      const collection = client.db("test").collection("devices");
    }
  });

  res.status(200).send('Success');
}

我确定驱动程序是最新的,并且我直接从 Atlas 文档中复制了大部分代码。我已将 Atlas 的所有 IP 列入白名单以进行测试。

每次函数运行时,我都会在连接回调中收到以下错误:

"{ Error: querySrv ESERVFAIL _mongodb._tcp.<CLUSTER-NAME>-vtbhs.mongodb.net
at errnoException (dns.js:28:10)
at QueryReqWrap.onresolve [as oncomplete] (dns.js:219:19)
code: 'ESERVFAIL',
errno: 'ESERVFAIL',
syscall: 'querySrv',
hostname: '_mongodb._tcp.<CLUSTER-NAME>-vtbhs.mongodb.net' }"

我之前也遇到过类似的错误:

URI does not have hostname, domain name and tld at module.exports

尽管自从我在 Mongo 中调整了密码(其中可能有一个非 html 编码的字符)后,这似乎不再弹出了。

提前感谢您的帮助!

4

2 回答 2

15

我有完全相同的问题。运行后,MongoDB Atlas 和 mLab 连接均失败firebase deploy,但在本地使用firebase serve.

我认为有两个问题:

  1. 免费 Spark 计划中禁用了出站网络。您必须升级到 Blaze 计划(即用即付)才能做到这一点。我刚换了层,现在可以了。

Spark 计划仅允许向 Google 拥有的服务发出出站网络请求。配额内允许入站调用请求。在 Blaze 计划中,Cloud Functions 提供永久免费层。每月免费提供前 2,000,000 次调用、400,000 GB-sec、200,000 CPU-sec 和 5 GB 的 Internet 出口流量。您只需为超出此免费配额的使用量付费。定价基于调用总数和计算时间。计算时间会根据为函数配置的内存量和 CPU 量而变化。使用限制也通过每日和 100 个配额来实施。有关更多信息,请参阅云函数定价。

https://firebase.google.com/pricing/

您必须提供信用卡,但只要您保持在他们的数据配额之下,显然您就不会被收费。我会试一试,看看效果如何。

  1. 升级后,您的 MongoDB Atlas 连接可能仍然失败(而 mLab 字符串可以工作)。这是因为您的查询 URI 使用的是 Mongo 3.6 SRV 地址,而不是 Mongo 3.4 驱动程序的“mongodb://”协议。尝试切换驱动程序版本,看看它是否有效。 在此处输入图像描述
于 2018-03-03T07:31:20.567 回答
0

在 Mongo Atlas 面板的白名单中设置“0.0.0.0/0”。

于 2020-02-28T10:56:06.250 回答