意见箱
恒创运营部门将仔细参阅您的意见和建议,必要时将通过预留邮箱与您保持联络。感谢您的支持!
意见/建议
提交建议

如何进行mongdb备份恢复

来源:恒创科技 编辑:恒创科技编辑部
2023-12-01 03:32:59

如何进行mongdb备份恢复,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、物理备份(拷贝文件)

#!/bin/sh
DATE=`date+%Y%m%d`
DEL_DATE=$(date-d'-30days'"+%Y%m%d")
HOST=10.10.17.27
PORT=27000
USER=admin
PASSWORD=123456
DATA_DIR="/data/mongodb/navy_db/db"
BACKUP_PATH="/data/mongodbbackup/$DATE"

date+%Y%m%d%H%M>>/data/log/mongodb_bak.log
#第一步锁表
lock()
{
echo"db.fsyncLock()"|mongo--host$HOST--port$PORT-u$USER-p$PASSWORDadmin
}
execute()
{
lock
if[$?-eq0]
then
echo"mongodblocksuccessfully!">>/data/log/mongodb_bak.log
else
echo"mongodblockfail!">>/data/log/mongodb_bak.log
fi
}
execute
#第二步备份
back()
{
rsync-av$DATA_DIR$BACKUP_PATH/
}
execute()
{
back
if[$?-eq0]
then
echo"mongodbbacksuccessfully!">>/data/log/mongodb_bak.log
else
echo"mongodbbackfail!">>/data/log/mongodb_bak.log
fi
}
execute
#第三部解锁
unlock()
{
echo"db.fsyncUnlock()"|mongo--host$HOST--port$PORT-u$USER-p$PASSWORDadmin
}
execute()
{
unlock
if[$?-eq0]
then
echo"mongodbunlocksuccessfully!">>/data/log/mongodb_bak.log
else
echo"mongodbunlockfail!">>/data/log/mongodb_bak.log
fi
}
execute
#删除历史数据
rm-rf"/data/mongodbbackup/${DEL_DATE}/"

PS:


如何进行mongdb备份恢复

物理备份只能全库恢复,不能恢复单个表

恢复步骤:

1、停止需要恢复的实例
2、备份清空/data/mongodb/navy_db/db目录
3、拷贝/data/mongodbbackup/$DATE下面的所有文件和文件夹到/data/mongodb/navy_db/db目录
4、chownmongod:mongod/data/mongodb/navy_db/db/-R
5、启动实例

二、mongodump备份

#!/bin/sh
DATE=`date+%Y%m%d`
DEL_DATE=$(date-d'-30days'"+%Y%m%d")
HOST=10.10.17.27:27000
USER=admin
PASSWORD=123456
BACKUP_PATH="/backup/mongodbbackup/$DATE"
date+%Y%m%d%H%M>>/data/log/mongodb_bak.log
start()
{
mongodump-h$HOST-u$USER-p$PASSWORD-o$BACKUP_PATH
}
execute()
{
start
if[$?-eq0]
then
echo"mongodbbacksuccessfully!">>/data/log/mongodb_bak.log
else
echo"mongodbbackfail!">>/data/log/mongodb_bak.log
fi
}
execute
rm-rf"/backup/mongodbbackup/${DEL_DATE}/"

恢复:

1、全库恢复

mongorestore--host10.10.17.27--port27000/backup/mongodbbackup/20150818/

2、单集合(表的概念)恢复

mongorestore--host10.10.17.27--port27001--dbnavy_db_new--collectionnavy_db_table_new/backup/mongodbbackup/20150818/navy_db/navy_db_table.bson

三、复制集备份

#!/bin/sh
DATE=`date+%Y%m%d`
DEL_DATE=$(date-d'-30days'"+%Y%m%d")
HOST="dbset/10.10.17.27:27000,10.10.17.26:27000"
USER=admin
PASSWORD=123456
BACKUP_PATH="/data/mongodbbackup/$DATE"
date+%Y%m%d%H%M>>/data/log/mongodb_bak.log
start()
{
mongodump-h$HOST-u$USER-p$PASSWORD--oplog-o$BACKUP_PATH
}
execute()
{
start
if[$?-eq0]
then
echo"mongodbbacksuccessfully!">>/data/log/mongodb_bak.log
else
echo"mongodbbackfail!">>/data/log/mongodb_bak.log
fi
}
execute
rm-rf"/backup/mongodbbackup/${DEL_DATE}/"

PS:

备份复制集和备份单个mongodb实例用mongodump备份的方法差不多,只是host的写法不一样,需要指定复制集名称,还有就是加上--oplog参数,来跟踪备份时主库上发生的所有写操作,获取一个pointin-time快照,否则备份的状态将与集 群中其他节点不匹配。在恢复时,还必须创建oplog,并指定--oplogReplay参数来应用这些操作,否则恢复的成员将不知道从何处开始同步,从 而在某个时间点上与源服务器保持一致。

恢复:

1、降复制集中要恢复的节点移除

rs.remove("10.10.17.26:27000")

2、运行mongorestore --oplogReplay命令

mongorestore--host10.10.17.26--port27000--oplogReplay/data/mongodbbackup/20150820/

3、创建oplog

uselocal
db.createCollection("oplog.rs",{"capped":true,"size":10000000})

4、恢复oplog

mongorestore--host10.10.17.26--port27000-dlocal-coplog.rs/data/mongodbbackup/20150820/oplog.bson

5、将该节点加入到复制集

rs.add("10.10.17.26:27000")

关于如何进行mongdb备份恢复问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注恒创行业资讯频道了解更多相关知识。

上一篇: mysql直接拷贝data目录下数据库源文件还原数据库方法 下一篇: JavaScript单线程和任务队列是什么