从 mongo 副本集中的特定节点读取数据
reading data from specific nodes in mongo replica set
我有一个包含三个成员的副本集。有没有可能我只想从两个辅助节点之一读取数据?我使用以下代码,其中 ip 是次要节点之一,但我仍然看到流量已部署到其他节点。
Mongo mongo = new MongoClient("171.21.43.34");
最好的方法是使用 mongodb 手册中所述的标签。
https://docs.mongodb.com/manual/tutorial/configure-replica-set-tag-sets/
conf = rs.conf()
conf.members[0].tags = { "offline": "false"}
conf.members[1].tags = { "offline": "false"}
conf.members[2].tags = { "offline": "true"}
rs.reconfig(conf)
在客户端中,您只需将读取首选项设置为该标签
MongoClientOptions options = MongoClientOptions
.builder()
.connectionsPerHost(config.connectionLimit)
.readPreference(TaggableReadPreference.secondaryPreferred(new TagSet(new Tag("offline", "true"))))
.socketTimeout(config.socketTimeout)
.connectTimeout(config.connectionTimeout)
.build();
mongo = new MongoClient(NewsDAOConfig.parseAddresses(config.mongoAddress), options);
我有一个包含三个成员的副本集。有没有可能我只想从两个辅助节点之一读取数据?我使用以下代码,其中 ip 是次要节点之一,但我仍然看到流量已部署到其他节点。
Mongo mongo = new MongoClient("171.21.43.34");
最好的方法是使用 mongodb 手册中所述的标签。
https://docs.mongodb.com/manual/tutorial/configure-replica-set-tag-sets/
conf = rs.conf()
conf.members[0].tags = { "offline": "false"}
conf.members[1].tags = { "offline": "false"}
conf.members[2].tags = { "offline": "true"}
rs.reconfig(conf)
在客户端中,您只需将读取首选项设置为该标签
MongoClientOptions options = MongoClientOptions
.builder()
.connectionsPerHost(config.connectionLimit)
.readPreference(TaggableReadPreference.secondaryPreferred(new TagSet(new Tag("offline", "true"))))
.socketTimeout(config.socketTimeout)
.connectTimeout(config.connectionTimeout)
.build();
mongo = new MongoClient(NewsDAOConfig.parseAddresses(config.mongoAddress), options);