MongoDB-啓動的時候出現了問題

以前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

相關文章
相關標籤/搜索