增加mongodb复制集的仲裁节点
目的
拥有4个节点(1primary 3secondary)的复制集理论上如果有任意一个节点宕机,均可保证集群选举出新的primary,保证集群的可用性。只是当前状态数据要保持4份,从磁盘空间利用率的角度来看不够节约,于是计划调整为1primary、2secondary、1ARBITER的模式。
步骤
查看集群状态
- 连接primary,运行rs.status()命令
- 选择id为2,即192.168.1.230:27017的节点作为仲裁节点
goluk:PRIMARY> rs.status() { "set" : "goluk", "date" : ISODate("2017-08-17T02:18:15.981Z"), "myState" : 1, "term" : NumberLong(-1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(1502936295, 493), "t" : NumberLong(-1) }, "appliedOpTime" : Timestamp(1502936295, 493), "durableOpTime" : Timestamp(1502936295, 481) }, "members" : [ { "_id" : 0, "name" : "10.0.1.31:27017", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 8479476, "optime" : Timestamp(1502936295, 493), "optimeDate" : ISODate("2017-08-17T02:18:15Z"), "electionTime" : Timestamp(1502896073, 1), "electionDate" : ISODate("2017-08-16T15:07:53Z"), "configVersion" : 10, "self" : true }, { "_id" : 1, "name" : "10.0.1.32:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 40222, "optime" : Timestamp(1502936294, 239), "optimeDurable" : Timestamp(1502936294, 239), "optimeDate" : ISODate("2017-08-17T02:18:14Z"), "optimeDurableDate" : ISODate("2017-08-17T02:18:14Z"), "lastHeartbeat" : ISODate("2017-08-17T02:18:14.589Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:18:15.485Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.33:27017", "configVersion" : 10 }, { "_id" : 2, "name" : "192.168.1.230:27017", "health" : 0, "state" : 8, "stateStr" : "(not reachable/healthy)", "uptime" : 0, "optime" : Timestamp(0, 0), "optimeDurable" : Timestamp(0, 0), "optimeDate" : ISODate("1970-01-01T00:00:00Z"), "optimeDurableDate" : ISODate("1970-01-01T00:00:00Z"), "lastHeartbeat" : ISODate("2017-08-17T02:18:14.515Z"), "lastHeartbeatRecv" : ISODate("2017-07-15T14:54:07.533Z"), "pingMs" : NumberLong(31), "lastHeartbeatMessage" : "Connection refused", "configVersion" : -1 }, { "_id" : 3, "name" : "10.0.1.33:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 2801929, "optime" : Timestamp(1502936295, 338), "optimeDurable" : Timestamp(1502936295, 337), "optimeDate" : ISODate("2017-08-17T02:18:15Z"), "optimeDurableDate" : ISODate("2017-08-17T02:18:15Z"), "lastHeartbeat" : ISODate("2017-08-17T02:18:15.421Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:18:14.407Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.31:27017", "configVersion" : 10 } ], "ok" : 1 }
移除230节点
- 在230节点上停止mongod进程
- 在primary上执行remove操作
goluk:PRIMARY> rs.remove("192.168.1.230:27017") { "ok" : 1 }
移除之后查看集群状态
goluk:PRIMARY> rs.status() { "set" : "goluk", "date" : ISODate("2017-08-17T02:20:03.647Z"), "myState" : 1, "term" : NumberLong(-1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(1502936403, 86), "t" : NumberLong(-1) }, "appliedOpTime" : Timestamp(1502936403, 292), "durableOpTime" : Timestamp(1502936403, 150) }, "members" : [ { "_id" : 0, "name" : "10.0.1.31:27017", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 8479584, "optime" : Timestamp(1502936403, 292), "optimeDate" : ISODate("2017-08-17T02:20:03Z"), "electionTime" : Timestamp(1502896073, 1), "electionDate" : ISODate("2017-08-16T15:07:53Z"), "configVersion" : 11, "self" : true }, { "_id" : 1, "name" : "10.0.1.32:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 40330, "optime" : Timestamp(1502936401, 721), "optimeDurable" : Timestamp(1502936401, 720), "optimeDate" : ISODate("2017-08-17T02:20:01Z"), "optimeDurableDate" : ISODate("2017-08-17T02:20:01Z"), "lastHeartbeat" : ISODate("2017-08-17T02:20:01.725Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:20:01.726Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.33:27017", "configVersion" : 11 }, { "_id" : 3, "name" : "10.0.1.33:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 2802036, "optime" : Timestamp(1502936401, 721), "optimeDurable" : Timestamp(1502936401, 721), "optimeDate" : ISODate("2017-08-17T02:20:01Z"), "optimeDurableDate" : ISODate("2017-08-17T02:20:01Z"), "lastHeartbeat" : ISODate("2017-08-17T02:20:01.725Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:20:01.764Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.31:27017", "configVersion" : 11 } ], "ok" : 1
增加仲裁节点
- 在230节点上重启mongod进程或者服务
- 在primary上执行增加仲裁节点命令
goluk:PRIMARY> rs.addArb("192.168.1.230:27017") { "ok" : 1 }
查看集群状态,确认仲裁节点
goluk:PRIMARY> rs.status() { "set" : "goluk", "date" : ISODate("2017-08-17T02:28:10.300Z"), "myState" : 1, "term" : NumberLong(-1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(1502936890, 59), "t" : NumberLong(-1) }, "appliedOpTime" : Timestamp(1502936890, 60), "durableOpTime" : Timestamp(1502936890, 36) }, "members" : [ { "_id" : 0, "name" : "10.0.1.31:27017", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 8480071, "optime" : Timestamp(1502936890, 60), "optimeDate" : ISODate("2017-08-17T02:28:10Z"), "electionTime" : Timestamp(1502896073, 1), "electionDate" : ISODate("2017-08-16T15:07:53Z"), "configVersion" : 12, "self" : true }, { "_id" : 1, "name" : "10.0.1.32:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 40817, "optime" : Timestamp(1502936889, 662), "optimeDurable" : Timestamp(1502936889, 662), "optimeDate" : ISODate("2017-08-17T02:28:09Z"), "optimeDurableDate" : ISODate("2017-08-17T02:28:09Z"), "lastHeartbeat" : ISODate("2017-08-17T02:28:09.915Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:28:09.981Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.33:27017", "configVersion" : 12 }, { "_id" : 3, "name" : "10.0.1.33:27017", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 2802523, "optime" : Timestamp(1502936889, 662), "optimeDurable" : Timestamp(1502936889, 662), "optimeDate" : ISODate("2017-08-17T02:28:09Z"), "optimeDurableDate" : ISODate("2017-08-17T02:28:09Z"), "lastHeartbeat" : ISODate("2017-08-17T02:28:09.916Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:28:09.978Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.0.1.31:27017", "configVersion" : 12 }, { "_id" : 4, "name" : "192.168.1.230:27017", "health" : 1, "state" : 7, "stateStr" : "ARBITER", "uptime" : 10, "lastHeartbeat" : ISODate("2017-08-17T02:28:10.170Z"), "lastHeartbeatRecv" : ISODate("2017-08-17T02:28:08.512Z"), "pingMs" : NumberLong(31), "configVersion" : 12 } ], "ok" : 1 }
在230上节点上继续确认是否更改为仲裁节点
- 执行mongo,可以发现提示符已经变更为ARBITER,确认修改成功
goluk:ARBITER>