[322]MongoDB库表备份(mongodump)与恢复(mongorestore)

find / -name mongo

先找到mongo的安装位置,cd /usr/local/mongodb/bin到这里

MongoDB数据备份

在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目录,这个目录里面存放该数据库实例的备份数据。

实例

在本地使用 27017 启动你的mongod服务。打开命令提示符窗口,进入MongoDB安装目录的bin目录输入命令mongodump:

>mongodump

执行以上命令后,客户端会连接到ip为 127.0.0.1 端口号为 27017 的MongoDB服务上,并备份所有数据到 bin/dump/ 目录中。命令输出结果如下:

MongoDB数据备份

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

语法描述实例
mongodump --host HOST_NAME --port PORT_NUMBER该命令将备份所有MongoDB数据mongodump --host runoob.com --port 27017
mongodump --dbpath DB_PATH --out BACKUP_DIRECTORYmongodump --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>
  • –host <:port>, -h <:port>: MongoDB所在服务器地址,默认为: localhost:27017

  • –db , -d : 需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2

  • –drop: 恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!

  • < path>: mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。

    你不能同时指定 和 --dir 选项,–dir也可以设置备份目录。

  • –dir: 指定备份的目录,你不能同时指定 和 --dir 选项。

接下来我们执行以下命令:

>mongorestore

执行以上命令输出结果如下:
MongoDB数据恢复


mongo库表导出导入备份

导出数据表
--host :要导出数据库 ip
--port :要导出的实例节点端口号
--username :数据库用户名
--password :数据库用户密码
--collection :要导出的表名
--db :要导出的表所在数据库名
--out :要导出的文件路径(默认为当前文件夹)

mongoexport  --host 172.31.128.120 --username admin --password FbQad6Ad6bV44 --collection eastmoney_lift --db bloom_filter --authenticationDatabase admin --out eastmoney_lift.json

mongoexport  --host 172.31.128.120 --username admin --password FbQad6Ad6bV44 --collection eastmoney_lift_quarter --db bloom_filter --authenticationDatabase admin --out eastmoney_lift_quarter.json
导入数据表
-- host :要导入的数据库 ip
--port :要导入的实例节点端口号
--username :数据库用户名
--password :数据库用户密码
--collection :要导入的表名
--db :要导入的表所在数据库名
--file :要导入的源文件路径(默认为当前文件夹)

mongoimport  --host 172.31.128.119 --username admin --password FbQad6Ad6bV44 --collection eastmoney_lift --db bloom_filter --authenticationDatabase admin --file eastmoney_lift.json

mongoimport  --host 172.31.128.119 --username admin --password FbQad6Ad6bV44 --collection eastmoney_lift_quarter --db bloom_filter --authenticationDatabase admin --file eastmoney_lift_quarter.json
导出数据库
#常用格式:
mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径 
#备份全库
mongodump -h ip -u xxx -p xxx --authenticationDatabase "admin" -o dump_bak/
#备份某个库
mongodump -h ip -u xxx -p xxx -d dbname --authenticationDatabase "admin" -o dump_bak/
导入数据库
#常用格式:
mongorestore -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 文件存在路径 
#导入全库
mongorestore -h IP -u xxx -p xxx --authenticationDatabase "admin" 路径
#导入某个库
mongorestore -h IP -u X -p X -d news --authenticationDatabase "admin" 路径/news/
#导入某个库并改名
mongorestore -h IP -u X -p X -d newsnn --authenticationDatabase "admin" 路径/news/
备份脚本
## 指定到你安装的Mongodb bin目录下的mongodump
dump=/usr/bin/mongodump
## 填写你创建dump_bak文件的绝对路径
out_dir=/data/backup/mongodb/dump_bak/
## 填写你创建tar_bak文件的绝对路径
tar_dir=/data/backup/mongodb/tar_bak/
## 记录备份时间
sysdate=`date +%Y_%m_%d`
db_user=admin
db_pass=FbQad6Ad6bV44
## 设置删除期限,删除10天前的备份
days=10
## 设置最终压缩的文件名称,带有日期
tar_bak="mondodb_bak_$sysdate.tar.gz"

cd $out_dir
# 创建新的文件夹存放dump文件
sudo mkdir -p $out_dir/$sysdate
# 导出172.18.9.123机器上的masterdata库的所有表到$out_dir/$sysdate文件夹
#$dump -h 172.31.128.119 -u $db_user -p $db_pass -d masterdata -o $out_dir/$sysdate
$dump -h 172.31.128.119 -u $db_user -p $db_pass -o $out_dir/$sysdate
# 压缩$out_dir/$sysdate到目标文件夹
tar -zcvf $tar_dir/$tar_bak $out_dir/$sysdate
# 删除指定期限钱的备份文件
find $tar_dir/ -mtime +$days -delete
# 退出
exit
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周小董

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值