连接到 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 版本。我没有看到任何关于在最新版本中使用副本集连接的文档,所以我不知道它是否已被弃用或不再提及。希望这可以帮助。
我正在尝试编写一个连接到两个数据库的 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 版本。我没有看到任何关于在最新版本中使用副本集连接的文档,所以我不知道它是否已被弃用或不再提及。希望这可以帮助。