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 --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] 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。
最后一種情況是/usr/bin/mongod的問題。它的報錯和目錄沒有讀寫權限一樣,但即使你把MongoDB的數據庫目錄設置成777,一樣會有問題。因為mongod是以O_NOATIME標志來訪問文件系統的,mongodb沒有這個權限,用setcap設置:
如果這樣都不行…備份數據庫然后apt-get purge 卸載重裝吧。