您好,登錄后才能下訂單哦!
這篇文章主要介紹解決mongodb在命令中啟動不了的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
場景:
使用/etc/init.d/mongodb start或是sudo service mongdb start,
提示mongodb start/running,但查看status仍然是stop/waiting。
解決方法:
1、service SERVERNAME status有可能誤報,先確認(rèn)MongoDB的實際狀態(tài)。
主要是ps axu|grep mongod查看是否有相關(guān)進(jìn)程,打開links或是直接用瀏覽器訪問127.0.0.1:28017,看不到MongoDB的信息說明沒有啟動。
2、然后執(zhí)行:
$ sudo mongod –repair –config /etc/mongodb.conf $ sudo mongod –config /etc/mongodb.conf
第一條命令是修復(fù)操作,
第二條命令是手動指定MongoDB的配置文件,
在終端中直接運行,這樣輸出錯誤時比較直觀,不用去翻日志。
如果能順利運行mongod,說明配置文件和數(shù)據(jù)庫都沒有問題,是/usr/bin/mongodb權(quán)限不夠,請參考本文結(jié)尾setcap方法。
如果不能運行,可以看到報錯信息,分三種情況:配置文件錯誤,數(shù)據(jù)目錄設(shè)置錯誤,/usr/bin/mongod文件錯誤。
1)配置文件錯誤比較明顯,參數(shù)錯誤會明確提示error command line: unknown option xxx。
第二條命令中明確指定使用的配置文件,也容易排錯。
所以除了之前配MongoDB主從修改配置文件弄壞過一次,很少遇到配置文件的問題。
2)其次是數(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
3)最后一種情況是/usr/bin/mongod的問題。
它的報錯和目錄沒有讀寫權(quán)限一樣,但即使你把MongoDB的數(shù)據(jù)庫目錄設(shè)置成777,一樣會有問題。
因為mongod是以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在命令中啟動不了的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。