標籤:
之前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: 14229ERROR: child process failed, exited with error number 100
修複方法:
這算是一個Mongod 啟動的一個常見錯誤,非法關閉的時候,lock 檔案沒有幹掉,第二次啟動的時候檢查到有lock 檔案的時候,就報這個錯誤了。
解決方案:進入 mongod 上一次啟動的時候指定的 data 目錄 --dbpath=/data/mongodb
刪除掉該檔案:
rm /data/mongodb/mongo.lock --linuxdel /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 admindb.shutdownServer()
也可以按照文檔粗暴的殺掉它,它內部應該有KILL訊號處理常式。
killall mongod
請不要 kill -9 ,會造成檔案資料混亂丟失 repair 也無力回天。
ctrl+c 可以退出mongo的介面 或是ext
MongoDB-啟動的時候出現了問題