MongoDB添加仲裁節(jié)點(diǎn)報(bào)錯(cuò):replica set IDs do not match的解決方法
背景:
由于歷史原因,某個(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ì)腳本之家的支持。
- Navicat遠(yuǎn)程連接MongoDB最全實(shí)現(xiàn)方法以及報(bào)錯(cuò)解決
- Mongodb 崩潰報(bào)錯(cuò) Too many open files的問(wèn)題解析
- 解決net start MongoDB 報(bào)錯(cuò)之服務(wù)名無(wú)效的問(wèn)題
- NodeJS連接MongoDB數(shù)據(jù)庫(kù)時(shí)報(bào)錯(cuò)的快速解決方法
- 關(guān)于mongoose連接mongodb重復(fù)訪(fǎng)問(wèn)報(bào)錯(cuò)的解決辦法
- Mongodb啟動(dòng)報(bào)錯(cuò)完美解決方案:about to fork child process,waiting until server is ready for connections.
相關(guān)文章
MongoDB數(shù)據(jù)庫(kù)安裝部署及警告優(yōu)化
大家好,本篇文章主要講的是MongoDB數(shù)據(jù)庫(kù)安裝部署及警告優(yōu)化,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話(huà)記得收藏一下,方便下次瀏覽2021-12-12MongoDB中數(shù)據(jù)的替換方法實(shí)現(xiàn)類(lèi)Replace()函數(shù)功能詳解
這篇文章主要介紹了MongoDB中數(shù)據(jù)的替換方法實(shí)現(xiàn)類(lèi)Replace()函數(shù)功能詳解,需要的朋友可以參考下2020-02-02MongoDB中多表關(guān)聯(lián)查詢(xún)($lookup)的深入講解
NoSql的多表關(guān)聯(lián)一直是比較復(fù)雜的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于MongoDB中多表關(guān)聯(lián)查詢(xún)($lookup)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-12-12MongoDB??數(shù)據(jù)模型的設(shè)計(jì)模式及優(yōu)缺點(diǎn)
這篇文章主要介紹了MongoDB??數(shù)據(jù)模型的設(shè)計(jì)模式,在實(shí)際開(kāi)發(fā)中,大多數(shù)性能問(wèn)題都可以追溯到糟糕的模型設(shè)計(jì),官方也提供分享過(guò)文檔模型設(shè)計(jì)的進(jìn)階技巧,這里簡(jiǎn)單翻譯記錄一下,需要的朋友可以參考下2022-12-12Mongodb 利用mongoshell進(jìn)行數(shù)據(jù)類(lèi)型轉(zhuǎn)換的實(shí)現(xiàn)方法
下面小編就為大家分享一篇Mongodb 利用mongoshell進(jìn)行數(shù)據(jù)類(lèi)型轉(zhuǎn)換的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12MongoDB在Windows平臺(tái)的安裝及配置方法
這篇文章主要介紹了MongoDB在Windows平臺(tái)的安裝及配置方法,簡(jiǎn)單分析了MongoDB的下載、設(shè)置方法、操作命令等具體步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-04-04

Mongodb 如何將時(shí)間戳轉(zhuǎn)換為年月日日期