使用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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:- 解决启动MongoDB错误:error while loading shared libraries: libstdc++.so.6:cannot open shared object file:
- 关于Mongodb参数说明与常见错误处理的总结
- Mongodb常见错误与解决方法小结(Mongodb中经常出现的错误)
- MongoDB错误32-bit servers don''t have journaling enabled by default解决方法
- 解决mongodb在ubuntu下启动失败,提示couldn‘t remove fs lock errno:9 Bad file descriptor的错误
- mongodb错误tcmalloc: large alloc out of memory, printing stack and exiting解决办法
- 修复 Mac brew 安装 mongodb 报 Error: No available formula with the name ‘mongodb’ 问题详解