- Reference >
- Database Commands >
- Administration Commands >
- repairDatabase
repairDatabase¶
Definition¶
- 
repairDatabase¶
- Checks and repairs errors and inconsistencies in data storage. - repairDatabaseis analogous to a- fsckcommand for file systems. Run the- repairDatabasecommand to ensure data integrity after the system experiences an unexpected system restart or crash, if:- The - mongodinstance is not running with journaling enabled.- Note - When using journaling, there is almost never any need to run - repairDatabase. In the event of an unclean shutdown, the server will be able restore the data files to a pristine state automatically.
- There are no other intact replica set members with a complete data set. - Warning - During normal operations, only use the - repairDatabasecommand and wrappers including- db.repairDatabase()in the- mongoshell and- mongod --repair, to compact database files and/or reclaim disk space. Be aware that these operations remove and do not save any corrupt data during the repair process.- If you are trying to repair a replica set member, and you have access to an intact copy of your data (e.g. a recent backup or an intact member of the replica set), you should restore from that intact copy, and not use - repairDatabase.
 - repairDatabasetakes the following form:- repairDatabasehas the following fields:- Field - Type - Description - preserveClonedFilesOnFailure- boolean - When - true,- repairDatabasewill not delete temporary files in the backup directory on error, and all new files are created with the “backup” instead of “_tmp” directory prefix. By default- repairDatabasedoes not delete temporary files, and uses the “_tmp” naming prefix for new files.- backupOriginalFiles- boolean - When - true,- repairDatabasemoves old database files to the backup directory instead of deleting them before moving new files into place. New files are created with the “backup” instead of “_tmp” directory prefix. By default,- repairDatabaseleaves temporary files unchanged, and uses the “_tmp” naming prefix for new files.- You can explicitly set the options as follows: - Warning - This command obtains a global write lock and will block other operations until it has completed. - Note - repairDatabaserequires free disk space equal to the size of your current data set plus 2 gigabytes. If the volume that holds dbpath lacks sufficient space, you can mount a separate volume and use that for the repair. When mounting a separate volume for- repairDatabaseyou must run- repairDatabasefrom the command line and use the- --repairpathswitch to specify the folder in which to store temporary repair files.- See - mongod --repairand- mongodump --repairfor information on these related options.
Behavior¶
The repairDatabase command compacts all collections in the
database. It is identical to running the compact command on
each collection individually.
repairDatabase reduces the total size of the data files on
disk. It also recreates all indexes in the database.
The time requirement for repairDatabase depends on the size of the
data set.
You may invoke repairDatabase from multiple contexts:
- Use the - mongoshell to run the command, as above.
- Use the - db.repairDatabase()in the- mongoshell.
- Run - mongoddirectly from your system’s shell. Make sure that- mongodisn’t already running, and that you invoke- mongodas a user that has access to MongoDB’s data files. Run as:- To add a repair path: - Note - mongod --repairwill fail if your database is not a master or primary. In most cases, you should recover a corrupt secondary using the data from an existing intact node. To run repair on a secondary/slave restart the instance in standalone mode without the- --replSetor- --slaveoptions.
Example¶
Using repairDatabase to Reclaim Disk Space¶
You should not use repairDatabase for data recovery
unless you have no other option.
However, if you trust that there is no corruption and you have enough
free space, then repairDatabase is the appropriate and
the only way to reclaim disk space.