MongoDb的“not master and slaveok=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 节点默认是不可读的,
 
   
  1. [mongodb@ligh bin]$ mongo 127.0.0.1:33333
  2. MongoDB shell version: 2.0.1
  3. connecting to: 127.0.0.1:33333/test
  4. SECONDARY> db.user.find()
  5. error: { "$err" : "not master and slaveok=false", "code" : 13435 }
  6. SECONDARY> db.getMongo()
  7. connection to 127.0.0.1:33333
  8. SECONDARY> db.getMongo().setSlaveOk();
  9. not master and slaveok=false

在主库上设置 slaveok=ok

 
  
  1. [mongodb@ligh bin]$ mongo 127.0.0.1:33333
  2. MongoDB shell version: 2.0.1
  3. connecting to: 127.0.0.1:33333/test
  4. PRIMARY> db.getMongo().setSlaveOk();
  5. PRIMARY>
  6. 在从库进行测试
  7. SECONDARY> db.user.find()
  8. { "_id" : ObjectId("4eb68b1540643e10a0000000"), "id" : 1, "name" : "zhangsan" }
  9. { "_id" : ObjectId("4eb68b1540643e10a0000001"), "id" : 2, "name" : ";lisi" }

另外可参考如下解决方案

http://stackoverflow.com/questions/8990158/mongdodb-replicates-and-error-err-not-master-and-slaveok-false-code



你可能感兴趣的:(数据库)