MongoDB無法啟動的解決方法


http://dmyz.org/archives/423

遇到MongoDB突然無法啟動,第一反應是刪除mongod.lock。這個文件在MongoDB的數據庫目錄下,默認是/data/db。這是最常見的問題了,產生原因是MongoDB沒有正常結束(比如被kill -9殺掉或是其他意外情況導致中斷)。

還一些其他情況會導致MongoDB無法啟動。本文討論的無法啟動,是指:使用/etc/init.d/mongodb start或是sudo service mongdb start,提示mongodb start/running,但查看status仍然是stop/waiting。

service SERVERNAME status有可能誤報,先確認MongoDB的實際狀態。主要是ps axu|grep mongod查看是否有相關進程,打開links或是直接用瀏覽器訪問127.0.0.1:28017,看不到MongoDB的信息說明沒有啟動。

然后執行:

$ sudo mongod --repair --config /etc/mongodb.conf
$ sudo mongod --config /etc/mongodb.conf

第一條命令是修復操作,第二條命令是手動指定MongoDB的配置文件,在終端中直接運行,這樣輸出錯誤時比較直觀,不用去翻日志。如果能順利運行mongod,說明配置文件和數據庫都沒有問題,是/usr/bin/mongodb權限不夠,請參考本文結尾setcap方法。

如果不能運行,可以看到報錯信息,分三種情況:配置文件錯誤,數據目錄設置錯誤,/usr/bin/mongod文件錯誤。

配置文件錯誤比較明顯,參數錯誤會明確提示error command line: unknown option xxx。第二條命令中明確指定使用的配置文件,也容易排錯。所以除了之前配MongoDB主從修改配置文件弄壞過一次,很少遇到配置文件的問題。

其次是數據目錄,主要是權限問題,可能的報錯是:

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

數據目錄的owner應該是mongodb:mongodb。

$ sudo chown mongodb:mongodb mongodb

最后一種情況是/usr/bin/mongod的問題。它的報錯和目錄沒有讀寫權限一樣,但即使你把MongoDB的數據庫目錄設置成777,一樣會有問題。因為mongod是以O_NOATIME標志來訪問文件系統的,mongodb沒有這個權限,用setcap設置:

# setcap cap_fowner+ep /usr/bin/mongod

如果這樣都不行…備份數據庫然后apt-get purge 卸載重裝吧。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM