Repairing a mongodb database folder after an unclean shutdown

When playing around with mongodb I once ended up with an unclean shutdown as a result of just killing the process without allowing for mongod to gracefully shutdown. As such I ended up with a non empty mongod.lock file, and I could not restart mongod. For a while I could not figure out what was wrong, but afyer checking the logs and doing a little research it turns out I just need to repair the database by juts giving a few options to mongod, and sure enough I was back up and running in no time. This will be a quick post about that experience.

1 - what to know

This is a quick post on how to go about repairing a mongodb database when it has become corrupted as a result of an unclean shutdown. I will also be briefly covering some related topics as well, but will not be getting into them in detail.

1.1 - What can cause it.

In my experience so far what caused it was an unclean shutdown by directly killing the mongod process, rather than shunting it down gracefully. This can result in a non empty mongod.lock file in the database folder that is being used. It could also happen because of an operating system crash, a power outage, or anything else that could result in an unclean shutdown. If jornaling is enable mongodb may be able to just deal with this automatically, but if it is not enabled well.

1.2 - May not need to do this if journaling is enabled

This is something that may not need to be done, if journaling is enabled, unless for some reason this does need to be done. In most cases an unclean shutdown can be cleared up automatically if journaling is enabled. Always be sure to check the logs first before doing anything.

1.2 - How to know if the database needs a repair.

Check the mongod.lock file in the database folder and see if it is not empty. It should just be a blank file 0kb in size, if this is not the case then the database may need to be repaired. It is also a good idea to look at the logs as well, in my experience it was showing that there where problems with permissions, and it also complained of an unclean shutdown.

2 - Start the repair

To start the repair just start mongod with the repair option and also give the location to the database. In my Linux environment the database was located at /var/lib/mongodb, but it could be at another location.

1
$ sudo mongod --repair --dbpath /var/lib/mongodb

If you are not sure where the database is located in the files system that would be a good thing to find out when it comes to these things. The location can be set from the command line when mognod is first started, or it can also be set via a configuration file that could at least potential be located anywhere and can be a conf, or yaml formated cfg file.

2.1 - Restarting mongod

After that if all goes well I should be able to restart mongod. In both Linux, and Windows I often run mongod as a service so I would do this in Linux:

1
$ sudo service mongodb start

And in windows I would use the services administrative tool to start up the mongod service again.

3 - Conclusion

This worked for me, but might not work out in all situations. When it comes to a real deployment of a real project the client database is something that should be backed up. If not you are really asking for trouble.