章工运维 章工运维
首页
  • linux
  • windows
  • 中间件
  • 监控
  • 网络
  • 存储
  • 安全
  • 防火墙
  • 数据库
  • 系统
  • docker
  • 运维工具
  • other
  • elk
  • K8S
  • ansible
  • Jenkins
  • GitLabCI_CD
  • 随笔
  • 面试
  • 工具
  • 收藏夹
  • Shell
  • python
  • golang
友链
  • 索引

    • 分类
    • 标签
    • 归档
    • 首页 (opens new window)
    • 关于我 (opens new window)
    • 图床 (opens new window)
    • 评论 (opens new window)
    • 导航栏 (opens new window)
周刊
GitHub (opens new window)

章工运维

业精于勤,荒于嬉
首页
  • linux
  • windows
  • 中间件
  • 监控
  • 网络
  • 存储
  • 安全
  • 防火墙
  • 数据库
  • 系统
  • docker
  • 运维工具
  • other
  • elk
  • K8S
  • ansible
  • Jenkins
  • GitLabCI_CD
  • 随笔
  • 面试
  • 工具
  • 收藏夹
  • Shell
  • python
  • golang
友链
  • 索引

    • 分类
    • 标签
    • 归档
    • 首页 (opens new window)
    • 关于我 (opens new window)
    • 图床 (opens new window)
    • 评论 (opens new window)
    • 导航栏 (opens new window)
周刊
GitHub (opens new window)
  • python

    • python基础

    • FastAPI

    • python每日练习脚本

      • 监控系统资源情况并发送邮件告警
      • 备份文件并发送邮件通知
      • 批量修改主机名
      • 监控文件夹大小变化并发送邮件通知
      • 批量修改多台主机的SSH端口
      • 监控Web服务器的HTTP响应状态码并发送警报
      • 自动化服务部署脚本01
      • 自动化服务部署脚本02
      • 自动化的系统健康检查和报告生成工具
      • 自动化的Docker容器生成报告脚本
      • 自动化数据库备份和恢复
    • python3给防火墙添加放行
    • python生成部署脚本
    • python将多个文件内容输出到一个文件中
    • 使用 Aligo 定时备份服务器文件
    • python监控日志文件并发送钉钉告警
    • python监控数据库脚本并发送钉钉告警
    • 使用python编写自动化发布脚本
    • 查询redis列表某个元素
    • centos7安装python3
    • python环境管理工具介绍
    • conda安装和镜像源配置
    • pip更换国内源
    • python爬虫
    • python环境启动服务报错缺少glibc库版本
    • 监控目录或文件变化
    • 批量更改文件
    • python引用数据库
  • shell

  • go

  • 编程
  • python
  • python每日练习脚本
章工运维
2024-07-16

自动化数据库备份和恢复

脚本如下

import os
import subprocess
import datetime
import oss2

# 数据库配置
DB_HOST = 'localhost'
DB_USER = 'your_username'
DB_PASSWORD = 'your_password'
DB_NAME = 'your_database'

# 备份配置
BACKUP_DIR = '/path/to/backup/dir'
BACKUP_RETENTION = 7  # 保留最近7天的备份

# 阿里云OSS配置
OSS_ENDPOINT = 'http://oss-cn-hangzhou.aliyuncs.com'  # 根据你的地域修改
OSS_BUCKET = 'your-oss-bucket'
OSS_ACCESS_KEY = 'your-oss-access-key'
OSS_SECRET_KEY = 'your-oss-secret-key'

def create_backup():
    """创建数据库备份"""
    timestamp = datetime.datetime.now().strftime('%Y%m%d_%H%M%S')
    backup_file = f"{BACKUP_DIR}/backup_{DB_NAME}_{timestamp}.sql"
    
    command = f"mysqldump -h {DB_HOST} -u {DB_USER} -p{DB_PASSWORD} {DB_NAME} > {backup_file}"
    
    try:
        subprocess.run(command, shell=True, check=True)
        print(f"备份成功:{backup_file}")
        return backup_file
    except subprocess.CalledProcessError as e:
        print(f"备份失败:{e}")
        return None

def upload_to_oss(file_path):
    """上传备份文件到阿里云OSS"""
    auth = oss2.Auth(OSS_ACCESS_KEY, OSS_SECRET_KEY)
    bucket = oss2.Bucket(auth, OSS_ENDPOINT, OSS_BUCKET)
    file_name = os.path.basename(file_path)
    
    try:
        bucket.put_object_from_file(file_name, file_path)
        print(f"文件上传到OSS成功:{file_name}")
    except oss2.exceptions.OssError as e:
        print(f"文件上传到OSS失败:{e}")

def cleanup_old_backups():
    """清理旧的备份文件"""
    now = datetime.datetime.now()
    for file in os.listdir(BACKUP_DIR):
        if file.startswith(f"backup_{DB_NAME}_") and file.endswith('.sql'):
            file_path = os.path.join(BACKUP_DIR, file)
            file_time = datetime.datetime.strptime(file.split('_')[2].split('.')[0], '%Y%m%d')
            if (now - file_time).days > BACKUP_RETENTION:
                os.remove(file_path)
                print(f"已删除旧备份:{file}")

def restore_backup(backup_file):
    """从备份文件恢复数据库"""
    command = f"mysql -h {DB_HOST} -u {DB_USER} -p{DB_PASSWORD} {DB_NAME} < {backup_file}"
    
    try:
        subprocess.run(command, shell=True, check=True)
        print(f"数据库恢复成功:{backup_file}")
    except subprocess.CalledProcessError as e:
        print(f"数据库恢复失败:{e}")

def main():
    # 创建备份
    backup_file = create_backup()
    if backup_file:
        # 上传到阿里云OSS
        upload_to_oss(backup_file)
        # 清理旧备份
        cleanup_old_backups()

    # 如果需要恢复数据库,取消下面的注释并指定要恢复的备份文件
    # restore_backup('/path/to/backup/file.sql')

if __name__ == '__main__':
    main()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
微信 支付宝
上次更新: 2024/12/04, 17:15:49

← 自动化的Docker容器生成报告脚本 python3给防火墙添加放行→

最近更新
01
shell脚本模块集合
05-13
02
生活小技巧(认知版)
04-29
03
生活小技巧(防骗版)
04-29
更多文章>
Theme by Vdoing | Copyright © 2019-2025 | 点击查看十年之约 | 鄂ICP备2024072800号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式