9.2. 备份和恢复

数据备份

在 MongoDB 中,使用 mongodump 命令来备份 MongoDB 数据。该命令可以导出所有数据到指定目录中。mongodump 命令可以通过参数指定导出的数据量级转存的服务器。mongodump 命令语法如下:

mongodump -h dbhost -d dbname -o dbdirectory
  • -h:MongDB 所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
  • -d:需要备份的数据库实例,例如:test
  • -o:备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在 dump 目录下建立一个 test 目录,这个目录里面存放该数据库实例的备份数据。

mongodump 命令可选参数列表如下所示:

语法 描述 实例
mongodump --host HOST_NAME --port PORT_NUMBER 该命令将备份所有 MongoDB 数据 mongodump --host runoob.com --port 27017
mongodump --dbpath DB_PATH --out BACKUP_DIRECTORY mongodump --dbpath /data/db/ --out /data/backup/
mongodump --collection COLLECTION --db DB_NAME 该命令将备份指定数据库的集合。 mongodump --collection mycol --db test

【示例】备份全量数据

$ mongodump -h 127.0.0.1 --port 27017 -o test2
...
2020-09-11T11:55:58.086+0800    done dumping test.company (18801 documents)
2020-09-11T11:56:00.725+0800    [#############...........]  test.people  559101/1000000  (55.9%)
2020-09-11T11:56:03.725+0800    [###################.....]  test.people  829496/1000000  (82.9%)
2020-09-11T11:56:06.725+0800    [#####################...]  test.people  884614/1000000  (88.5%)
2020-09-11T11:56:08.088+0800    [########################]  test.people  1000000/1000000  (100.0%)
2020-09-11T11:56:08.350+0800    done dumping test.people (1000000 documents)

【示例】备份指定数据库

mongodump -h 127.0.0.1 --port 27017 -d admin -o test3

数据恢复

MongoDB 使用 mongorestore 命令来恢复备份的数据。mongorestore 命令语法如下:

> mongorestore -h <hostname><:port> -d dbname <path>
  • --host <:port>, -h <:port>:MongoDB 所在服务器地址,默认为: localhost:27017
  • --db , -d :需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如 test2
  • --drop:恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!
  • <path>:mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。你不能同时指定 <path>--dir 选项,--dir 也可以设置备份目录。
  • --dir:指定备份的目录。你不能同时指定 <path>--dir 选项。

【示例】

$ mongorestore -h 127.0.0.1 --port 27017 -d test --dir test --drop
...
2020-09-11T11:46:16.053+0800    finished restoring test.tweets (966 documents, 0 failures)
2020-09-11T11:46:18.256+0800    [###.....................]  test.people  164MB/1.03GB  (15.6%)
2020-09-11T11:46:21.255+0800    [########................]  test.people  364MB/1.03GB  (34.6%)
2020-09-11T11:46:24.256+0800    [############............]  test.people  558MB/1.03GB  (53.0%)
2020-09-11T11:46:27.255+0800    [###############.........]  test.people  700MB/1.03GB  (66.5%)
2020-09-11T11:46:30.257+0800    [###################.....]  test.people  846MB/1.03GB  (80.3%)
2020-09-11T11:46:33.255+0800    [######################..]  test.people  990MB/1.03GB  (94.0%)
2020-09-11T11:46:34.542+0800    [########################]  test.people  1.03GB/1.03GB  (100.0%)
2020-09-11T11:46:34.543+0800    no indexes to restore
2020-09-11T11:46:34.543+0800    finished restoring test.people (1000000 documents, 0 failures)
2020-09-11T11:46:34.544+0800    1000966 document(s) restored successfully. 0 document(s) failed to restore.
下一节:mongoimport 和 mongoexport 并不能可靠地保存所有的富文本 BSON 数据类型,因为 JSON 仅能代表一种 BSON 支持的子集类型。因此,数据用这些工具导出导入或许会丢失一些精确程度。