以前MongoDB啓動的時候是正常的,不知道後來啓動報錯了,就把粘貼出來查詢了。最後才知道是因爲本身不正常的關閉致使的這個狀況。php
--摘錄:MongoDB非正常關閉後修復記錄linux
mongod沒有後臺執行,在終端鏈接非正常斷開後,再次執行mongod報錯,以下所示:mongodb
2015-03-09T20:39:20.172+0800 2015-03-09T20:39:20.172+0800 warning: 32-bit servers don't have journaling enabled by default. Please use --journal if you want durability. 2015-03-09T20:39:20.172+0800 about to fork child process, waiting until server is ready for connections. forked process: 14229 ERROR: child process failed, exited with error number 100
修復方法:shell
這算是一個Mongod 啓動的一個常見錯誤,非法關閉的時候,lock 文件沒有幹掉,第二次啓動的時候檢查到有lock 文件的時候,就報這個錯誤了。windows
解決方法:進入 mongod 上一次啓動的時候指定的 data 目錄 --dbpath=/data/mongodbapp
刪除掉該文件:post
rm /data/mongodb/mongo.lock --linux del /data/mongodb/mongo.lock --windows
再執行:spa
./mongod --repair
啓動:code
/usr/local/mongodb$ /usr/local/mongodb/mongod -dbpath=/data/mongodb --fork --port 27017 --logpath=/usr/local/mongodb/log/work.log --logappend --auth
OK,問題解決。server
正確關閉mongod 的方法:進入mongo shell
use admin
db.shutdownServer()
也能夠按照文檔粗暴的殺掉它,它內部應該有KILL信號處理程序。
killall mongod
請不要 kill -9 ,會形成文件數據混亂丟失 repair 也無力迴天。
ctrl+c 能夠退出mongo的界面 或是ext