3

我正在运行一个复制的 mongoDB,我可以使用 mongo 连接到集合中的主数据库没有问题:

bash-4.2$ mongo --port 25023
MongoDB shell version: 3.2.6
rs0:PRIMARY>

但是当像这样使用猫鼬时:

mongoose.connect('mongodb://127.0.0.1:25023/XXX', { useNewUrlParser: true });

我得到:

XXX/node_modules/mongoose/lib/utils.js:452       
throw err;
    ^
MongoError: not master and slaveOk=false
   at queryCallback (/XXX/node_modules/mongodb-core/lib/cursor.js:247:25)

建议是这样做:

mongodb://user:password@host:port,replicaSetHost:replicaSetPort/database?replicaSet=rs-someServer.

但这有点笨拙。有没有办法告诉猫鼬我们正在连接到主服务器而不是从服务器?

第二个问题......即使列出其他主机也不起作用:

mongoose.connect('mongodb://localhost:P,S1:P,S2:P/XXX?replicaSet=rs0', { useNewUrlParser: true });

即使我提供了副本集,我也会收到此错误:

(node:13757) UnhandledPromiseRejectionWarning: Unhandled promise rejection  (rejection id: 1): MongoError: seed list contains no mongos proxies, replicaset connections requires the parameter replicaSet to be supplied in the URI or options object, mongodb://server:port/db?replicaSet=name

这就是奇怪的地方:我可以完成这项工作。如果我使用这条线:

mongoose.connect('mongodb://127.0.0.1:25023/XXX', { useNewUrlParser: true });

让它失败,然后碰一个JS文件强制重启一个NodeJS,然后它似乎开始工作了?

4

1 回答 1

3

同样的问题,基本上我想连接到副本集中的主节点(写问题),但我间歇性地连接到辅助节点(竞争条件)。

解决方案/TLDR;

添加?replicaSet=test&w=majority到您的 MONGO_URL 连接字符串。


从文档...

具有高写入关注度的副本集

以下连接到具有写入关注点的副本集,该副本集配置为等待复制在大多数承载数据的投票成员中成功,超时时间为 2 秒。

笔记

对于副本集,指定副本集配置中列出的 mongod 实例的主机名。

mongodb://example1.com,example2.com,example3.com/?replicaSet=test&w=majority&wtimeoutMS=2000
于 2019-11-22T04:08:25.420 回答