如何进行mongdb备份恢复-创新互联

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

成都网络公司-成都网站建设公司创新互联十多年经验成就非凡,专业从事网站设计、网站建设,成都网页设计,成都网页制作,软文推广广告投放平台等。十多年来已成功提供全面的成都网站建设方案,打造行业特色的成都网站建设案例,建站热线:028-86922220,我们期待您的来电!

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

#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%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 $PASSWORD  admin } execute() {   lock   if [ $? -eq 0 ]   then     echo "mongodb lock successfully!" >>/data/log/mongodb_bak.log   else     echo "mongodb lock fail!" >>/data/log/mongodb_bak.log   fi } execute #第二步备份 back() { rsync -av $DATA_DIR $BACKUP_PATH/ } execute() {   back   if [ $? -eq 0 ]   then     echo "mongodb back successfully!" >>/data/log/mongodb_bak.log   else     echo "mongodb back fail!" >>/data/log/mongodb_bak.log   fi } execute #第三部解锁 unlock() { echo "db.fsyncUnlock()"|  mongo  --host $HOST --port $PORT -u $USER -p $PASSWORD  admin } execute() {   unlock   if [ $? -eq 0 ]   then     echo "mongodb unlock successfully!" >>/data/log/mongodb_bak.log   else     echo "mongodb unlock fail!" >>/data/log/mongodb_bak.log   fi } execute #删除历史数据 rm -rf "/data/mongodbbackup/${DEL_DATE}/"

PS:

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

恢复步骤:

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

二、mongodump备份

#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%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 [ $? -eq 0 ]   then     echo "mongodb back successfully!" >>/data/log/mongodb_bak.log   else     echo "mongodb back fail!" >>/data/log/mongodb_bak.log   fi } execute rm -rf "/backup/mongodbbackup/${DEL_DATE}/"

恢复:

1、全库恢复

mongorestore --host 10.10.17.27 --port  27000   /backup/mongodbbackup/20150818/

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

 mongorestore --host 10.10.17.27 --port  27001 --db navy_db_new --collection navy_db_table_new   /backup/mongodbbackup/20150818/navy_db/navy_db_table.bson

三、复制集备份

#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%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 [ $? -eq 0 ]   then     echo "mongodb back successfully!" >>/data/log/mongodb_bak.log   else     echo "mongodb back fail!" >>/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 --host 10.10.17.26 --port  27000 --oplogReplay  /data/mongodbbackup/20150820/

3、创建oplog

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

4、恢复oplog

mongorestore --host 10.10.17.26 --port  27000 -d local -c oplog.rs  /data/mongodbbackup/20150820/oplog.bson

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

 rs.add("10.10.17.26:27000")

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

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网页名称:如何进行mongdb备份恢复-创新互联
标题URL:http://pwwzsj.com/article/djdgds.html