将一个mongodb的普通数据节点修改为passive节点,也就是能同步数据、投票,但是不能成为primary节点。
除了仲裁节点,其他每个节点都有个代表优先权priority的值,我们可以通过设置优先权来决定谁成为primary的权重最大。
MongoDB replica sets中通过设置priority的值来决定优先权的大小,这个值的范围是0--100,值越大,优先权越高。
如果值是0,那么不能成为primay。
-
通过rs.conf()命令查看出节点列表:
以下为我的实验mongodb集群:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
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的竞争。
命令格式如下:
|
1
2
3
4
5
|
cfg = rs.conf()
cfg.members[0].priority = 0.5
cfg.members[1].priority = 2
cfg.members[2].priority = 2
rs.reconfig(cfg)
|
说明:cfg.members[0].priority =
中括号中的数字是执行rs.conf()得出的节点顺序,第一个节点在这里写0,第二个节点写1,依次类推。
执行命令:
|
1
2
3
|
cfg = rs.conf()
cfg.members[1].priority = 0
rs.reconfig(cfg)
|
查看集群状态:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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的竞争。
本文转自 icenycmh 51CTO博客,原文链接:http://blog.51cto.com/icenycmh/1840196,如需转载请自行联系原作者