您好,登錄后才能下訂單哦!
小編給大家分享一下mongodb服務(wù)無法開啟的解決方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
MongoDB無法啟動的解決方法
遇到MongoDB突然無法啟動,第一反應(yīng)是刪除mongod.lock。這個文件在MongoDB的數(shù)據(jù)庫目錄下,默認(rèn)是/data/db。這是最常見
的問題了,產(chǎn)生原因是MongoDB沒有正常結(jié)束(比如被kill -9殺掉或是其他意外情況導(dǎo)致中斷)。
還一些其他情況會導(dǎo)致MongoDB無法啟動。本文討論的無法啟動,是指:使用/etc/init.d/mongodb start或是sudo service mongdb
start,提示mongodb start/running,但查看status仍然是stop/waiting。
service SERVERNAME status有可能誤報,先確認(rèn)MongoDB的實(shí)際狀態(tài)。主要是ps axu|grep mongod查看是否有相關(guān)進(jìn)程,打開
links或是直接用瀏覽器訪問127.0.0.1:28017,看不到MongoDB的信息說明沒有啟動。
然后執(zhí)行:
$ sudo mongod –repair –config /etc/mongodb.conf $ sudo mongod –config /etc/mongodb.conf
第一條命令是修復(fù)操作,第二條命令是手動指定MongoDB的配置文件,在終端中直接運(yùn)行,這樣輸出錯誤時比較直觀,不用去翻日志。
如果能順利運(yùn)行mongod,說明配置文件和數(shù)據(jù)庫都沒有問題,是/usr/bin/mongodb權(quán)限不夠,請參考本文結(jié)尾setcap方法。
如果不能運(yùn)行,可以看到報錯信息,分三種情況:配置文件錯誤,數(shù)據(jù)目錄設(shè)置錯誤,/usr/bin/mongod文件錯誤。
配置文件錯誤比較明顯,參數(shù)錯誤會明確提示error command line: unknown option xxx。第二條命令中明確指定使用的配置文件,也
容易排錯。所以除了之前配MongoDB主從修改配置文件弄壞過一次,很少遇到配置文件的問題。
其次是數(shù)據(jù)目錄,主要是權(quán)限問題,可能的報錯是:
Thu 22 11 10:03:30 [initandlisten] warning couldn’t write to / rename file /srv/mongodb/journal/prealloc.0 Thu 22 11 10:03:30 [initandlisten] couldn’t open /srv/mongodb/duoshuo.ns errno:1 Operation not permitted Thu 22 11 10:03:30 [initandlisten] error couldn’t open file /srv/mongodb/duoshuo.ns terminating
數(shù)據(jù)目錄的owner應(yīng)該是mongodb:mongodb。
$ sudo chown mongodb:mongodb mongodb
最后一種情況是/usr/bin/mongod的問題。它的報錯和目錄沒有讀寫權(quán)限一樣,但即使你把MongoDB的數(shù)據(jù)庫目錄設(shè)置成777,一樣會
有問題。因?yàn)閙ongod是以O(shè)_NOATIME標(biāo)志來訪問文件系統(tǒng)的,mongodb沒有這個權(quán)限,用setcap設(shè)置:
# setcap cap_fowner+ep /usr/bin/mongod
如果這樣都不行…備份數(shù)據(jù)庫然后apt-get purge 卸載重裝吧。
看完了這篇文章,相信你對mongodb服務(wù)無法開啟的解決方法有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。