Reputation: 47851
I'm getting a strange error in my node.js app
not master and slaveOk=false code 13435
I'm doing a findOne query using mongoose 4.0.2 hitting a mongodb 3.0.1. The query was working earlier today.
What is this error? I'm running on mongohq on their standard per gb plan.
Upvotes: 47
Views: 82854
Reputation: 619
You can use readPreference
to your connection string.
mongodb://localhost:27017/?readPreference=secondary&directConnection=true&ssl=false
when primary does not allow you to connect, you can use secondary preference.
Upvotes: 3
Reputation: 9997
That means you're trying to read from a secondary node in a replica set, you can only read from the primary node by default.
You can allow a secondary node to accept reads by running rs.slaveOk()
in a mongo shell that is connected to that secondary node. Allowing reads from a secondary is not recommended, because you could be reading stale data if the node isn't yet synced with the primary node.
UPDATE: As Janusz Slota's comment points out, rs.slaveOk()
is no longer used. Use rs.secondaryOk()
instead, however this is still not recommended. Here's the documentation for rs.secondaryOk().
Upvotes: 49
Reputation: 2469
I solved this by simply fixing the URI my Node.js application was using to connect to MongoDB with Mongoose.
When this error ocurred, my URI was
mongodb://user:password@host:port/datatabase
,
and this was giving me the error not master and slaveOK=false.
Then I changed the URI to add the Replica Set information, and the URI became something like this:
mongodb://user:password@host:port,replicaSetHost:replicaSetPort/database?replicaSet=rs-someServer
.
Now, I don't know if this is a general pattern, because this configuration is the one used by MongoLab, which is where my DataBase is hosted. However, it's likely you will solve the problem by adding the replica set information in the URI as well.
Upvotes: 24
Reputation: 635
It is likely your master node failed and you are trying to read from a slave node but by default (and a safety practice such as data synchronization) your reading source is set to primary node only.
You can attach options at the end of your connection string such as
?readPreference=secondary
which will use the secondary connection
Upvotes: 3
Reputation: 391
I solved the problem(happened by connecting to a instance of mongoDB on IBM) with
mongoose.connect('mongodb://host1:port1/?replicaSet=rsName');
From: https://mongoosejs.com/docs/connections.html#replicaset_connections
Upvotes: 6
Reputation: 557
This works for me on mongoose 4.x and mongodb 3.0.x:
model.find().read('secondary').....
see http://mongoosejs.com/docs/api.html#query_Query-read
Upvotes: 2