我有一个数据库包装类,建立一个连接到一些MongoDB实例:

async connect(connectionString: string): Promise<void> {
        this.client = await MongoClient.connect(connectionString)
        this.db = this.client.db()
}

这给了我一个警告:

(node:4833) DeprecationWarning:当前URL字符串解析器已弃用,并将在未来版本中删除。要使用新的解析器,将选项{useNewUrlParser: true}传递给MongoClient.connect。

connect()方法接受一个MongoClientOptions实例作为第二个参数。但它没有useNewUrlParser属性。我还尝试在连接字符串中设置这些属性,就像这样:mongodb://127.0.0.1/my-db?useNewUrlParser=true,但它对那些警告没有影响。

那么我怎么能设置useneurlparser删除这些警告?这对我来说很重要,因为脚本应该以cron的方式运行,而这些警告会导致垃圾邮件。

我使用3.1.0-beta4版本的mongodb驱动程序,并在3.0.18中使用相应的@types/mongodb包。它们都是npm install可用的最新版本。

解决方案

使用旧版本的mongodb驱动程序:

"mongodb": "~3.0.8",
"@types/mongodb": "~3.0.18"

当前回答

正如我们所注意到的,驱动程序的3.1.0-beta4版本从目前的情况来看,“被释放到野外”有点早。该版本是正在进行的工作的一部分,以支持即将发布的MongoDB 4.0中的新特性,并进行一些其他API更改。

其中一个触发当前警告的更改是useNewUrlParser选项,这是由于传递连接URI的实际工作方式发生了一些更改。稍后再详细介绍。

在事情“安定下来”之前,建议至少“固定”到3.0的次要版本。x版本:

  "dependencies": {
    "mongodb": "~3.0.8"
  }

这应该会阻止3.1。X分支安装在节点模块的“新鲜”安装上。如果您已经安装了“最新”版本,即“测试版”,那么您应该清理您的包(以及包锁)。Json),并确保将其降至3.0。X系列发布。

至于实际使用"new"连接URI选项,主要的限制是在连接字符串中实际包含端口:

const { MongoClient } = require("mongodb");
const uri = 'mongodb://localhost:27017';  // mongodb://localhost - will fail

(async function() {
  try {

    const client = await MongoClient.connect(uri,{ useNewUrlParser: true });
    // ... anything

    client.close();
  } catch(e) {
    console.error(e)
  }

})()

这是新法规中更为“严格”的规定。主要的一点是,当前的代码本质上是“node-native-driver”(npm mongodb)存储库代码的一部分,而“新代码”实际上是从“支撑”“公共”节点驱动的mongodb-core库中导入的。

添加“选项”的目的是通过将选项添加到新代码中来“简化”转换,因此在添加选项和清除deprecation警告的代码中使用更新的解析器(实际上是基于url的),从而验证传入的连接字符串实际上符合新解析器的期望。

在未来的版本中,“遗留的”解析器将被删除,然后新的解析器将被简单地使用,即使没有选项。但是到那时,所有现有的代码都有足够的机会根据新的解析器的期望来测试它们现有的连接字符串。

因此,如果你想在新的驱动特性发布时就开始使用它们,那么使用可用的beta版和后续版本,理想情况下,通过在MongoClient.connect()中启用useNewUrlParser选项,确保你提供了一个对新解析器有效的连接字符串。

如果您实际上不需要访问与MongoDB 4.0预览版相关的特性,那么可以将版本固定在3.0。X系列,如前所述。这将像文档所描述的那样工作,并且“固定”这将确保3.1。X版本不会在预期的依赖关系之上“更新”,直到您真正想要安装一个稳定的版本。

其他回答

如果用户名或密码有@字符,那么像这样使用它:

mongoose
    .connect(
        'DB_url',
        { user: '@dmin', pass: 'p@ssword', useNewUrlParser: true }
    )
    .then(() => console.log('Connected to MongoDB'))
    .catch(err => console.log('Could not connect to MongoDB', err));

我是这么说的。直到几天前我更新了npm,这个提示才在我的控制台显示出来。

.connect有三个参数,URI, options和err。

mongoose.connect(
    keys.getDbConnectionString(),
    { useNewUrlParser: true },
    err => {
        if (err) 
            throw err;
        console.log(`Successfully connected to database.`);
    }
);

你需要在猫鼬.connect()方法中添加{useNewUrlParser: true}。

mongoose.connect('mongodb://localhost:27017/Notification',{ useNewUrlParser: true });

正如我们所注意到的,驱动程序的3.1.0-beta4版本从目前的情况来看,“被释放到野外”有点早。该版本是正在进行的工作的一部分,以支持即将发布的MongoDB 4.0中的新特性,并进行一些其他API更改。

其中一个触发当前警告的更改是useNewUrlParser选项,这是由于传递连接URI的实际工作方式发生了一些更改。稍后再详细介绍。

在事情“安定下来”之前,建议至少“固定”到3.0的次要版本。x版本:

  "dependencies": {
    "mongodb": "~3.0.8"
  }

这应该会阻止3.1。X分支安装在节点模块的“新鲜”安装上。如果您已经安装了“最新”版本,即“测试版”,那么您应该清理您的包(以及包锁)。Json),并确保将其降至3.0。X系列发布。

至于实际使用"new"连接URI选项,主要的限制是在连接字符串中实际包含端口:

const { MongoClient } = require("mongodb");
const uri = 'mongodb://localhost:27017';  // mongodb://localhost - will fail

(async function() {
  try {

    const client = await MongoClient.connect(uri,{ useNewUrlParser: true });
    // ... anything

    client.close();
  } catch(e) {
    console.error(e)
  }

})()

这是新法规中更为“严格”的规定。主要的一点是,当前的代码本质上是“node-native-driver”(npm mongodb)存储库代码的一部分,而“新代码”实际上是从“支撑”“公共”节点驱动的mongodb-core库中导入的。

添加“选项”的目的是通过将选项添加到新代码中来“简化”转换,因此在添加选项和清除deprecation警告的代码中使用更新的解析器(实际上是基于url的),从而验证传入的连接字符串实际上符合新解析器的期望。

在未来的版本中,“遗留的”解析器将被删除,然后新的解析器将被简单地使用,即使没有选项。但是到那时,所有现有的代码都有足够的机会根据新的解析器的期望来测试它们现有的连接字符串。

因此,如果你想在新的驱动特性发布时就开始使用它们,那么使用可用的beta版和后续版本,理想情况下,通过在MongoClient.connect()中启用useNewUrlParser选项,确保你提供了一个对新解析器有效的连接字符串。

如果您实际上不需要访问与MongoDB 4.0预览版相关的特性,那么可以将版本固定在3.0。X系列,如前所述。这将像文档所描述的那样工作,并且“固定”这将确保3.1。X版本不会在预期的依赖关系之上“更新”,直到您真正想要安装一个稳定的版本。

这几行代码同样适用于所有其他弃用警告:

const db = await mongoose.createConnection(url, { useNewUrlParser: true });
mongoose.set('useCreateIndex', true);
mongoose.set('useFindAndModify', false);