linux下定时备份mongodb数据

2020-09-21 18:43:25 浏览数 (1)

前言

在linux服务器上通过用shell语言 python完成对mongo库的定时备份

使用方法

通过命令nohup python -u mongod_back.py > out.log 2>&1 & 挂在脚本,每天0点执行mongodb数据备份。

python脚本 """ * Create by dell on 2020/9/19 * Author :wencheng * 微信公众 :自动化测试 To share """ import time import schedule import os def auto_backup_mongo() : commands = """ cd /home/webapp/backup/mongo_bak && pwd && ./mongod_bak.sh """ os.system(commands) schedule.every().day.at("23:59").do(auto_backup_mongo)while True: schedule.run_pending() time.sleep(1) shell脚本 """ * Create by dell on 2020/9/19 * Author :wencheng * 微信公众 :自动化测试 To share """ #!/bin/sh DUMP=/home/webapp/Downloads/mongoDB/mongodbserver/bin/mongodump #mongodump备份文件执行路径 OUT_DIR=/home/webapp/backup/mongo_bak/mongod_bak_now #临时备份目录 TAR_DIR=/home/webapp/backup/mongo_bak/mongod_bak_list #备份存放路径 DATE=`date %Y_%m_%d_%H_%M_%S` #获取当前系统时间 DB_USER=XXXX#数据库账号 DB_PASS=XXXX #数据库密码 DB_NAME=TEST #数据库名称 IP=xx.xx.xx.xx:27017 DAYS=365 #DAYS=30代表删除30天前的备份,即只保留最近30天的备份 TAR_BAK="mongod_bak_$DATE.tar.gz" #最终保存的数据库备份文件名 cd $OUT_DIR rm -rf $OUT_DIR/* mkdir -p $OUT_DIR/$DATE $DUMP -h $IP -u $DB_USER -p $DB_PASS -d $DB_NAME -o $OUT_DIR/$DATE #备份数据库 tar -zcvf $TAR_DIR/$TAR_BAK $OUT_DIR/$DATE #压缩为.tar.gz格式 find $TAR_DIR/ -mtime $DAYS -delete #删除30天前的备份 exit #件

0 人点赞