在写多读少的应用中,使用Replica Sets来实现读写分离。
通过在连接时指定或者在主库指定slaveOk,由Secondary来分担读的压力,Primary只承担写操作
通过在连接时指定或者在主库指定slaveOk,由Secondary来分担读的压力,Primary只承担写操作
对于replica set 中的secondary 节点默认是不可读的
[mongodb@rac4 bin]$ mongo 127.0.0.1:28019
MongoDB shell version: 2.0.1
connecting to: 127.0.0.1:28019/test
SECONDARY> db.user.find()
error: { "$err" : "not master and slaveok=false", "code" : 13435 }
SECONDARY> db.getMongo()
connection to 127.0.0.1:28019
SECONDARY> db.getMongo().setSlaveOk();
not master and slaveok=false
在主库上设置 slaveok=ok
[mongodb@rac4 bin]$ mongo 127.0.0.1:28018
MongoDB shell version: 2.0.1
connecting to: 127.0.0.1:28019/test
PRIMARY> db.getMongo().setSlaveOk();
PRIMARY>
这样就可以实现读写分离操作了。
本文介绍如何在MongoDB中使用ReplicaSets实现读写分离,包括设置主从库、调整副本集成员读取权限以及利用slaveOk参数优化读操作性能。
976

被折叠的 条评论
为什么被折叠?



