背景:
由于歷史原因,某個(gè)MongoDB副本集只有一主一從雙節(jié)點(diǎn),無(wú)法滿(mǎn)足自動(dòng)故障轉(zhuǎn)移要求,需要配置一個(gè)仲裁節(jié)點(diǎn)。
原有節(jié)點(diǎn)192.168.10.20:27017,192.168.10.21:27017,現(xiàn)在準(zhǔn)備在20上配置一個(gè)新節(jié)點(diǎn)27018當(dāng)做仲裁
在當(dāng)前主節(jié)點(diǎn)上執(zhí)行
repset:PRIMARY> cfg={_id:"repset", members:[{_id:0, host:'192.168.10.20:27017', priority:1},{_id:2, host:'192.168.10.21:27017', priority:2}, {_id:3, host:'192.168.10.20:27018', arbiterOnly:true}]};
repset:PRIMARY> rs.reconfig(cfg)

顯示配置是成功的,接著用命令查看副本集狀態(tài)時(shí),發(fā)現(xiàn)仲裁節(jié)點(diǎn)不可用,報(bào)錯(cuò)信息replica set IDs do not match。
repset:PRIMARY> rs.status()

網(wǎng)上的各種文檔都是說(shuō)①查看副本集的名稱(chēng)是否一致 ②把節(jié)點(diǎn)上的數(shù)據(jù)全都刪掉。
我在確認(rèn)副本集配置名稱(chēng)一致后,刪除仲裁節(jié)點(diǎn)的數(shù)據(jù)時(shí)發(fā)現(xiàn):1、通過(guò)客戶(hù)端是無(wú)法刪除副本集配置集合;2、刪除底層物理文件會(huì)導(dǎo)致Mongod進(jìn)程啟動(dòng)失敗。
在仔細(xì)回想initiate一次性副本集配置的操作時(shí),發(fā)現(xiàn)配置后,只啟動(dòng)了一個(gè)客戶(hù)端。我的猜想是會(huì)不會(huì)是因?yàn)槲覇?dòng)了仲裁節(jié)點(diǎn)的客戶(hù)端,仲裁節(jié)點(diǎn)生成了單獨(dú)的副本集ID。
于是我將仲裁節(jié)點(diǎn)的配置文件db、log、Mongodb.conf全都刪除,并重新命令啟動(dòng)仲裁節(jié)點(diǎn)MongoD進(jìn)程后,直接在當(dāng)前Primary節(jié)點(diǎn)按之前的操作添加仲裁節(jié)點(diǎn)后,發(fā)現(xiàn)仲裁節(jié)點(diǎn)已正常。

結(jié)論:
目前只是證實(shí)了我的猜想,還沒(méi)找到官方的說(shuō)法。
在添加副本集節(jié)點(diǎn)的時(shí)候,新增的節(jié)點(diǎn)在啟動(dòng)服務(wù)后,一定不要連接客戶(hù)端,否則新增節(jié)點(diǎn)會(huì)生成另外的副本集ID,雖然副本集名稱(chēng)一致,但是IDs不一致會(huì)報(bào)錯(cuò)。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- MongoDB啟動(dòng)報(bào)錯(cuò) 28663 Cannot start server
- NodeJS連接MongoDB數(shù)據(jù)庫(kù)時(shí)報(bào)錯(cuò)的快速解決方法
- 關(guān)于mongoose連接mongodb重復(fù)訪問(wèn)報(bào)錯(cuò)的解決辦法
- perl操作MongoDB報(bào)錯(cuò)undefined symbol: HeUTF8解決方法
- Mongodb 崩潰報(bào)錯(cuò) Too many open files的問(wèn)題解析