Life is like a shower. One wrong turn and you’re in hot water.
生活就像淋浴,方向转错,水深火热。
MongoDB在副本集中,会自动进行主节点的选举,主节点选举的触发条件:
rs.stepDown(600)
)一旦触发选举,就要根据一定规则来选主节点。
选举规则是根据票数来决定:
oplog
来对比的。在获得票数的时候,优先级(priority)参数影响重大。
可以通过设置优先级(priority)来设置额外票数。优先级即权重,取值为0-1000,相当于可额外增加0-1000的票数,优先级的值越大,就越可能获得多数成员的投票(votes)数。指定较高的值可使成员更有资格成为主要成员,更低的值可使成员更不符合条件。
默认情况下,优先级的值是1
myrs:SECONDARY> rs.conf() { "_id" : "myrs", "version" : 221242, "term" : 4, "members" : [ { "_id" : 0, "host" : "192.168.20.131:27017", "priority" : 1, }, { "_id" : 1, "host" : "localhost.localdomain:27018", "priority" : 1, }, { "_id" : 2, "host" : "192.168.20.131:27019", "priority" : 1, }, { "_id" : 3, "host" : "192.168.20.131:27020", "priority" : 1, }, { "_id" : 4, "host" : "192.168.20.131:27030", "priority" : 0, } ], ... } myrs:SECONDARY>
可以看出,主节点和副本节点的优先级各为1,即,默认可以认为都已经有了一票。但选举节点,优先级是0,(要注意是,官方说了,选举节点的优先级必须是0,不能是别的值。即不具备选举权,但具有投票权)
通过下面的步骤可以提升从节点的优先级:
# 先将配置导入cfg变量 myrs:SECONDARY> cfg=rs.conf() # 然后修改值(ID号默认从0开始): myrs:SECONDARY> cfg.members[1].priority=2 # 重新加载配置 myrs:SECONDARY> rs.reconfig(cfg)
一杯清水能滋润一寸土地,一缕阳光能驱散一丝阴影。勿以善小而不为,在日常生活中,有时候做一件好事,仅仅是举手之劳。要是每个人都能像雷锋那样,把做好事当成一种自觉的行动,把关心他人作为一种义务和责任,聚沙成塔,积少成多,我们的生活一定会更加美好,我们的社会一定会更加和谐。