之前MongoDB啟動的時候是正常的,不知道后來啟動報錯了,就把粘貼出來查詢了。最后才知道是由於自己不正常的關閉導致的這個情況。
--摘錄:MongoDB非正常關閉后修復記錄
mongod沒有后台執行,在終端連接非正常斷開后,再次執行mongod報錯,如下所示:
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
修復方法:
這算是一個Mongod 啟動的一個常見錯誤,非法關閉的時候,lock 文件沒有干掉,第二次啟動的時候檢查到有lock 文件的時候,就報這個錯誤了。
解決方法:進入 mongod 上一次啟動的時候指定的 data 目錄 --dbpath=/data/mongodb
刪除掉該文件:
rm /data/mongodb/mongo.lock --linux del /data/mongodb/mongo.lock --windows
再執行:
./mongod --repair
啟動:
/usr/local/mongodb$ /usr/local/mongodb/mongod -dbpath=/data/mongodb --fork --port 27017 --logpath=/usr/local/mongodb/log/work.log --logappend --auth
OK,問題解決。
正確關閉mongod 的方法:進入mongo shell
use admin
db.shutdownServer()
也可以按照文檔粗暴的殺掉它,它內部應該有KILL信號處理程序。
killall mongod
請不要 kill -9 ,會造成文件數據混亂丟失 repair 也無力回天。
ctrl+c 可以退出mongo的界面 或是ext