连接到 mongo shell 内的副本集

Connect to replica set within mongo shell

我正在尝试编写一个连接到两个数据库的 Mongo shell 脚本,在一个数据库中搜索一些文档,然后将找到的文档插入另一个数据库.有点像这样:

#!/bin/sh
mongo --shell --nodb <<EOF
var db1 = new Mongo( '...' );
var db2 = new Mongo( '...' );
db1.collection.findOne( {...} ).forEach( function( r ) { 
  db2.collection.save( r ) 
});

诀窍是,两个数据库都是副本集,并且需要用户名和密码。

使用 new Mongo() 连接到副本集并作为特定用户进行身份验证的语法是什么?我尝试使用 Mongo URI (http://docs.mongodb.org/manual/reference/connection-string/),但没有用。

我没有副本集来测试它,但我认为你可以像这样使用 Mongo() 构造函数

conn = Mongo("replicasetname/host:port")

从那里我认为你需要用

手动获取数据库

db = conn.getDB("myDatabase")

然后验证

db.auth(user, pass)

这也可能取决于您使用的 shell 版本。我没有看到任何关于在最新版本中使用副本集连接的文档,所以我不知道它是否已被弃用或不再提及。希望这可以帮助。