MongoDB 备份(mongodump)与恢复(mongorestore)
# MongoDB数据备份
在Mongodb
中我们使用mongodump
命令来备份MongoDB
数据。该命令可以导出所有数据到指定目录中。
mongodump
命令可以通过参数指定导出的数据量级转存的服务器。
# 语法
mongodump
命令脚本语法如下:
mongodump -h dbhost -d dbname -o dbdirectory
1
-h:
MongoDB 所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
-d:
需要备份的数据库实例,例如:test
-o:
备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 实例
mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径
# 例如:
mongodump -h 127.0.0.1 --port 27019 -u user -p xxxx --authenticationDatabase admin -d data-db -o /out/data
1
2
3
2
3
执行以上命令后,客户端会连接到ip为 127.0.0.1
端口号为 27017
的MongoDB
服务上,并备份所有数据到 bin/dump/
目录中。
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 |
# MongoDB数据恢复
mongodb
使用 mongorestore
命令来恢复备份的数据。
# 语法
mongorestore
命令脚本语法如下:
mongorestore -h <hostname><:port> -d dbname <path>
1
--host <:port>, -h <:port>:
MongoDB所在服务器地址,默认为: localhost:27017
--db , -d :
需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2
--drop:
恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!
<path>:
mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。
你不能同时指定 <path> 和 --dir 选项,--dir也可以设置备份目录。
--dir:
指定备份的目录
你不能同时指定 <path> 和 --dir 选项。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# 实例
mongorestore -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 --drop 文件存在路径
# 例如:
mongorestore -h 127.0.0.1 --port 27019 -d data-db --drop /out/data
1
2
3
2
3
上次更新: 2024/05/29, 17:27:32
- 02
- Node与GLIBC_2.27不兼容解决方案08-19
- 03
- Git清空本地文件跟踪缓存08-13