hitl 发表于 2018-10-25 12:21:05

Mongodb被动(passive)节点配置

  将一个mongodb的普通数据节点修改为passive节点,也就是能同步数据、投票,但是不能成为primary节点。
  除了仲裁节点,其他每个节点都有个代表优先权priority的值,我们可以通过设置优先权来决定谁成为primary的权重最大。
  MongoDB replica sets中通过设置priority的值来决定优先权的大小,这个值的范围是0--100,值越大,优先权越高。
  如果值是0,那么不能成为primay。

[*]  通过rs.conf()命令查看出节点列表:
  以下为我的实验mongodb集群:
PRIMARY> rs.conf()  
{
  
"_id" : "test",
  
"version" : 22,
  
"members" : [
  
{
  
"_id" : 3,
  
"host" : "192.168.22.36:27017"
  
},
  
{
  
"_id" : 5,
  
"host" : "192.168.22.10:27017"
  
},
  
{
  
"_id" : 6,
  
"host" : "192.168.22.12:27017",
  
"priority" : 0,
  
"arbiterOnly" : true
  
},
  
{
  
"_id" : 7,
  
"host" : "192.168.22.115:27017"
  
}
  
]
  
}
  2.将上面的192.168.22.10节点的priority值修改成0,让它只接收数据,不参与成为primary的竞争。
  命令格式如下:
cfg = rs.conf()  
cfg.members.priority = 0.5
  
cfg.members.priority = 2
  
cfg.members.priority = 2
  
rs.reconfig(cfg)
  说明:cfg.members.priority =
  中括号中的数字是执行rs.conf()得出的节点顺序,第一个节点在这里写0,第二个节点写1,依次类推。
  执行命令:
cfg = rs.conf()  
cfg.members.priority = 0
  
rs.reconfig(cfg)
  查看集群状态:
PRIMARY> rs.conf()  
{
  
"_id" : "test",
  
"version" : 22,
  
"members" : [
  
{
  
"_id" : 3,
  
"host" : "192.168.22.36:27017"
  
},
  
{
  
"_id" : 5,
  
"host" : "192.168.22.10:27017"
  
"priority" : 0
  
},
  
{
  
"_id" : 6,
  
"host" : "192.168.22.12:27017",
  
"priority" : 0,
  
"arbiterOnly" : true
  
},
  
{
  
"_id" : 7,
  
"host" : "192.168.22.115:27017"
  
}
  
]
  
}
  可以看到192.168.22.10:27017节点的priority的值变为0,这时候它只接收数据,不参与primary的竞争。


页: [1]
查看完整版本: Mongodb被动(passive)节点配置