MongoDb的"notmasterandslaveok=false"错误及如何解决方法

雪花,是世界上最圣洁的花,当你静静的倾听天籁,尘世的浮躁与喧嚣,似乎都已离你远去,剩下的惟有纯净,那是心灵忘却一切的畅然,那是在没有尘埃的世界里,生命自由呼吸的平淡与安恬。

使用mongodb时,出现“not master and slaveok=false”错误,原因是secondary不允许读写。

因为系统中mongodb做了主备,主备切换了,也可能导致这个问题。

把命令mongo --username=root --password=123456 --host=192.168.0.100 admin中的ip换成主ip后查询正常。

问题说明:

首先这是正常的,因为SECONDARY是不允许读写的,在写多读少的应用中,使用Replica Sets来实现读写分离。通过在连接时指定或者在主库指定slaveOk,由Secondary来分担读的压力,Primary只承担写操作。

对于replica set 中的secondary 节点默认是不可读的,


在主库上设置slaveok=ok

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接

您可能有感兴趣的文章
mongos崩溃后无法重启问题的如何解决方法

MongoDB游标超时问题的4种如何解决方法

MongoDB磁盘IO问题的3种如何解决方法

MongoDB最大连接数设置失效的异常分析过程与如何解决方法

MongoDB诡异问题之sh.stopBalancer卡住的如何解决方法