I am querying mongo oplog in MongoLabs mongoDb. As Mongolabs doesn't allow one to create user for local, I created an oplog-reader in admin but it throws error showing that it is unauthorised:
Code snippet:
var oplogURL = 'mongodb://<oplog-user>:<password>@node1,node2:port/admin?replicaSet=rs-<relpset>';
var allLocalURL = 'mongodb://<oplog-user>:<password>@node1,node2:port/local?replicaSet=rs-<relpset>'; //user on admin with "readWriteAnyDatabase" permisson, trying to use local db
var allReaderURL='mongodb://<user>:<password>@node1,node2:port/admin?replicaSet=rs-<relpset>'; //user on admin with "readWriteAnyDatabase" permisson
var db = mongoose.createConnection(oplogURL,{replset: { poolSize: 50 }}, function (err, res){
if (err) {console.log("Oops!"); console.log(err);}
});
var opschema = new mongoose.Schema({v:"Number", op:"String", ns:"String"}, { strict: false});
var oplogModel = db.model('oplogModel', opschema, 'oplog.rs');
oplogModel.find().exec(function(err, res){
//oplogModel.find().sort('-ts').limit(1).select('ts').exec(function(err, res){
if (err) {console.log("Oopps!"); console.log(err);}
console.log (res);
});
I get :
{ [MongoError: not authorized for query on admin.oplog.rs]
name: 'MongoError',
message: 'not authorized for query on admin.oplog.rs',
'$err': 'not authorized for query on admin.oplog.rs',
code: 13 }
When I use allLocalURL:
{ [MongoError: not authorized for query on local.oplog.rs]
name: 'MongoError',
message: 'not authorized for query on local.oplog.rs',
'$err': 'not authorized for query on local.oplog.rs',
code: 13 }
When I use allReaderURL:
[]
But I can log into mongo shell and query the oplog using oplog-reader user and switching the db to local. I can also tail oplog by mongo-oplog by using the oplog-user on admin.
How should I create the mongo URL/Query to get data from oplog.rs??