【Mysql备份】Python脚本备份docker的MySQL数据

  1. 可配置备份文件保留天数
  2. 可配置指定表不备份
import os
import time
import schedule
from datetime import date, timedelta  

DB_user = "root"
DB_password = "root"
DB_name = "demo"
SUDO_Password = ''
DOCKER_image = "5390aaed0e9c"
FILE_SAVE_path = "/prod/backup/"
# 备份文件保留天数
FILE_SAVE_DATE = 5

def execute():
    del_file()
    backup()
    
def backup():
    IGNORED_TABLES_STRING = ""
    # 不备份的表
    EXCLUDED_TABLES = [
        'log_data',
        'log_data202210',
        'log_data202209',
        'log_login',
        'log_operation',
        'log_request',
    ]
    for table_name in EXCLUDED_TABLES:
        IGNORED_TABLES_STRING += " --ignore-table=" + DB_name + "." + table_name

    FILEPATH = FILE_SAVE_path + "demo_`date +%F`.sql"
    command = "docker exec " + DOCKER_image + " sh -c 'exec mysqldump -u " + DB_user + " -p" + DB_password + " " + DB_name + \
        " " + IGNORED_TABLES_STRING + "' > " + FILEPATH
    
    print(command)
    os.system('echo %s|sudo -S %s' % (SUDO_Password, command))
    
def del_file():
    dt = date.today() - timedelta(FILE_SAVE_DATE)
    filePath = FILE_SAVE_path + 'demo_' + dt.strftime("%Y-%m-%d") + ".sql"
    if os.path.exists(filePath):
        os.remove(filePath)
        print("删除已有文件 " + filePath)

"""
schedule.every(2).seconds.do(job)     # 部署每2s执行一次job()函数的任务
schedule.every(2).minutes.do(job)       # 部署每2分钟执行一次job()函数的任务
schedule.every().hour.do(job)            # 部署每×小时执行一次job()函数的任务
schedule.every().day.at("10:30").do(job)  # 部署在每天的10:30执行job()函数的任务
schedule.every().monday.do(job)          # 部署每个星期一执行job()函数的任务
schedule.every().wednesday.at("13:15").do(job) # 部署每周三的13:15执行函数的任务
"""
schedule.every().day.at("02:30").do(execute)

if __name__ == "__main__":
    while True:
        schedule.run_pending()
        time.sleep(1)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值