以前MongoDB啓動的時候是蠻正常的,不知道後來啓動報錯了,就把粘貼出來查詢了。最後才知道是因爲本身不正常的關閉致使的這個狀況。
--摘錄:MongoDB非正常關閉後修復記錄
mongod沒有後臺執行,在終端鏈接非正常斷開後,再次執行mongod報錯,以下所示:
[root@localhost mongodb]# ./bin/mongod ./bin/mongod --help for help and startup options Thu Nov 17 22:42:49 Thu Nov 17 22:42:49 warning: 32-bit servers don't have journaling enabled by default. Please use --journal if you want durability. Thu Nov 17 22:42:49 Thu Nov 17 22:42:49 [initandlisten] MongoDB starting : pid=3257 port=27017 dbpath=/data/db/ 32-bit host=localhost Thu Nov 17 22:42:49 [initandlisten] Thu Nov 17 22:42:49 [initandlisten] ** NOTE: when using MongoDB 32 bit, you are limited to about 2 gigabytes of data Thu Nov 17 22:42:49 [initandlisten] ** seehttp://blog.mongodb.org/post/137788967/32-bit-limitations Thu Nov 17 22:42:49 [initandlisten] ** with --journal, the limit is lower Thu Nov 17 22:42:49 [initandlisten] Thu Nov 17 22:42:49 [initandlisten] db version v2.0.1, pdfile version 4.5 Thu Nov 17 22:42:49 [initandlisten] git version: 3a5cf0e2134a830d38d2d1aae7e88cac31bdd684 Thu Nov 17 22:42:49 [initandlisten] build info: Linux domU-12-31-39-01-70-B4 2.6.21.7-2.fc8xen #1 SMP Fri Feb 15 12:39:36 EST 2008 i686 BOOST_LIB_VERSION=1_41 Thu Nov 17 22:42:49 [initandlisten] options: {} ************** Unclean shutdown detected. Please visit http://dochub.mongodb.org/core/repair for recovery instructions. ************* Thu Nov 17 22:42:49 [initandlisten] exception in initAndListen: 12596 old lock file, terminating Thu Nov 17 22:42:49 dbexit: Thu Nov 17 22:42:49 [initandlisten] shutdown: going to close listening sockets... Thu Nov 17 22:42:49 [initandlisten] shutdown: going to flush diaglog... Thu Nov 17 22:42:49 [initandlisten] shutdown: going to close sockets... Thu Nov 17 22:42:49 [initandlisten] shutdown: waiting for fs preallocator... Thu Nov 17 22:42:49 [initandlisten] shutdown: closing all files... Thu Nov 17 22:42:49 [initandlisten] closeAllFiles() finished Thu Nov 17 22:42:49 dbexit: really exiting now
修復方法:
這算是一個Mongod 啓動的一個常見錯誤,非法關閉的時候,lock 文件沒有幹掉,第二次啓動的時候檢查到有lock 文件的時候,就報這個錯誤了。
解決方法:進入 mongod 上一次啓動的時候指定的 data 目錄 --dbpath=/data/mongodb
刪除掉該文件:
rm /data/mongodb/mongo.lock --linux
del /data/mongodb/mongo.lock --windows
再執行:
./mongod --repair
啓動:
/usr/local/src/mongodb-linux-x86_64-2.0.2/bin/mongod --port=27017 --pidfilepath=/var/run/mongod.pid --dbpath=/data/mongodb --directoryperdb --nojournal --noauth
OK,問題解決。
正確關閉mongod 的方法:進入mongo shell
use admin
db.shutdownServer()
也能夠按照文檔粗暴的殺掉它,它內部應該有KILL信號處理程序。
killall mongod
請不要 kill -9 ,會形成文件數據混亂丟失 repair 也無力迴天。
ctrl+c 能夠退出mongo的界面 或是ext
好了,成功以後,在瀏覽器打開一下
這樣就成功了,注:有些地方會寫成localhost這裏用 ip 測試。有些沒有代理,因此用localhost沒法打開。