mongodbレプリカセットノードの1つをプライマリライブラリとして強制し、レプリカセットクラスタを再作成する

5852 ワード

mongodbコピーセットクラスタでは、n/2+1個のノードが失われ、つまり多数のノードが失われた場合、クラスタ内で残りのノードがメインライブラリになる人を投票採決できない場合は、そのうちの1つのノードをメインライブラリに強制する必要がある.次は操作手順です:1.cfg=rs.conf()2を実行する.必要な_を設定する必要がありますidメインライブラリ、cfg.members=[cfg.members[3]] 3.クラスタ再設定4を実行する.rs.reconfig(cfg, {force: true}); 5.rs.status()
以下は、4つのノードのコピーセットである、3つのノードが失われ、残りのノードをプライマリノードとし、単一のインスタンスで実行する詳細な操作手順である.cfg=rs.conf()を実行し、クラスタのノード情報を取得します.
cms:SECONDARY>  cfg=rs.conf() 
{
        "_id" : "cms",
        "version" : 32948,
        "protocolVersion" : NumberLong(1),
        "members" : [
                {
                        "_id" : 0,
                        "host" : "192.168.1.193:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {

                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                },
                {
                        "_id" : 1,
                        "host" : "192.168.1.195:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {

                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                },
                {
                        "_id" : 2,
                        "host" : "192.168.1.198:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {

                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                },
                {
                        "_id" : 3,
                        "host" : "192.168.1.199:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {

                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                }
        ],
        "settings" : {
                "chainingAllowed" : true,
                "heartbeatIntervalMillis" : 2000,
                "heartbeatTimeoutSecs" : 10,
                "electionTimeoutMillis" : 10000,
                "getLastErrorModes" : {

                },
                "getLastErrorDefaults" : {
                        "w" : 1,
                        "wtimeout" : 0
                },
                "replicaSetId" : ObjectId("59cab0d69b86b9e815cfc02b")
        }
}

次に199をプライマリノードとして指定する
cms:SECONDARY> cfg.members=[cfg.members[3]]
[
        {
                "_id" : 3,
                "host" : "192.168.1.199:27017",
                "arbiterOnly" : false,
                "buildIndexes" : true,
                "hidden" : false,
                "priority" : 1,
                "tags" : {

                },
                "slaveDelay" : NumberLong(0),
                "votes" : 1
        }
]

cms:SECONDARY>  rs.reconfig(cfg, {force: true})
{ "ok" : 1 }


変更後のクラスタ状態を確認すると、操作が完了し、単一インスタンスノードとなる.次に、スレーブノードを追加してレプリカセットを実装します.
cms:SECONDARY> rs.status()
{
        "set" : "cms",
        "date" : ISODate("2018-09-04T01:54:12.445Z"),
        "myState" : 1,
        "term" : NumberLong(6),
        "heartbeatIntervalMillis" : NumberLong(2000),
        "members" : [
                {
                        "_id" : 3,
                        "name" : "192.168.1.199:27017",
                        "health" : 1,
                        "state" : 1,
                        "stateStr" : "PRIMARY",
                        "uptime" : 3152420,
                        "optime" : {
                                "ts" : Timestamp(1536026052, 24),
                                "t" : NumberLong(6)
                        },
                        "optimeDate" : ISODate("2018-09-04T01:54:12Z"),
                        "infoMessage" : "could not find member to sync from",
                        "electionTime" : Timestamp(1536026047, 1),
                        "electionDate" : ISODate("2018-09-04T01:54:07Z"),
                        "configVersion" : 137682,
                        "self" : true
                }
        ],
        "ok" : 1
}

新しいノードを追加:
config = { _id:"cms", members:
[
{_id:0,host:"192.168.1.193:27017"},
{_id:1,host:"192.168.1.194:27017"},
{_id:2,host:"192.168.1.198:27017"},
{_id:3,host:"192.168.1.199:27017"}
]
}       

rs.reconfig(config);

その後、新しいノードでmongodプロセスを開始するには、新しいノードのデータファイルを空にする必要があります.ノードが起動すると、メインライブラリのデータが自動的にプルされ、インデックスが作成されます.mongod --fork --config/data0/mongodb/mongod.conf