MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
对象存储 OSS,20GB 3个月
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。

之前我写过一个临时的 MySQL 备份脚本,主要是为了应急使用,功能比较简单。现在有时间了,我重新整理了一下,让它不仅能自动备份数据库,还支持远程服务器同步和上传到阿里云 OSS,这样即使本地备份丢失,数据也不会完全丢失。

现在,这个脚本已经发布到 GitHub,地址在这里:
👉 GitHub 仓库 - mysql-backup-shell


这个脚本做了什么?

这个脚本的核心功能包括:

  • 自动备份 MySQL 数据库,每天定时运行(可通过 crontab​ 设置)。
  • 本地存储:按日期分类存放备份文件,并自动删除过期备份,避免磁盘占满。
  • 远程服务器同步:支持通过 rsync​ 传输备份到另一台服务器,确保数据冗余。
  • 阿里云 OSS 备份:可以将备份文件上传到阿里云对象存储,进一步增强安全性。
  • 自动清理过期备份:定期清理本地、远程和 OSS 上的旧备份,减少存储成本。

你可以在 mysql_backup.sh​ 中修改配置,根据自己的需求调整备份策略。


如何使用?

1. 下载脚本

git clone https://github.com/zxc7563598/mysql-backup-shell.git
cd mysql-backup-shell
chmod +x mysql_backup.sh

然后修改 mysql_backup.sh​ 里的参数,确保 MySQL​ 连接信息正确。

2. 设置定时任务

执行 crontab -e​,然后添加:

0 3 * * * /path/to/mysql_backup.sh

这样每天凌晨 3:00 就会自动执行备份。


远程服务器同步配置

如果想把备份同步到另一台服务器,需要配置 SSH 免密登录。

1. 生成 SSH 密钥

在本机执行:

ssh-keygen -t rsa -b 4096 -f ~/.ssh/my_backup_key

然后把生成的 my_backup_key.pub​ 复制到远程服务器:

ssh-copy-id -i ~/.ssh/my_backup_key.pub user@remote_server_ip

修改脚本配置:

enable_ssh_sync=true  # 是否启用 SSH 同步(true/false)
enable_ssh_clean=true  # 是否清理远程服务器上的备份(true/false)
ssh_ip="182.22.13.33"  # 远程服务器 IP
ssh_port=22  # SSH 端口
ssh_user="root"  # 登录远程服务器的用户名
clientPath="/home/backup/mysql/"  # 远程服务器存储路径

配置完成后,脚本运行时就能把备份同步到远程服务器了。


阿里云 OSS 备份配置

1. 安装 ossutil

需要安装 ossutil,阿里云有十分完善的文档,点击查看:安装ossutil

仅需完成官方文档中的第一步安装 ossutil 使其命令可用即可,不需要执行官方文档中的 ossutil config​ 对 ossutil 进行配置

2. 创建Bucket

进入 对象存储OSS - Bucket列表,创建 Bucket,用于存放数据库备份文件

3. 获取阿里云 AccessKey

进入 阿里云 AccessKey 管理,创建 AccessKey 并记录 AccessKey ID​ 和 AccessKey Secret​。

3. 修改脚本配置

enable_oss_upload=true  # 是否启用 OSS 上传(true/false)
enable_oss_clean=true  # 是否清理阿里云 OSS 上的备份(true/false)
oss_bucket="oss://Bucket名称/想存储的文件夹路径/"  # OSS 目标路径
oss_access_key="your-access-key-id"  # 阿里云 AccessKey
oss_secret_key="your-access-key-secret"  # 阿里云 Secret
oss_endpoint="oss-cn-hangzhou.aliyuncs.com"  # OSS 访问地址,在对应 bucket 的概览中可以看到外网访问的 Endpoint

配置完成后,脚本运行时备份文件就会自动上传到 OSS 了。


结语

这个脚本能帮助你轻松管理 MySQL 备份,支持本地存储、远程同步和阿里云 OSS 备份。如果你也需要定期备份数据库,可以试试这个仓库:

👉 GitHub 仓库 - mysql-backup-shell 🚀

如果有任何问题或改进建议,欢迎提 Issue 或 Fork 进行优化!

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
119 28
|
1月前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
59 15
|
29天前
|
SQL Oracle 关系型数据库
在MySQL Shell里 重启MySQL 8.4实例
在MySQL Shell里 重启MySQL 8.4实例
52 2
|
3月前
|
SQL 监控 关系型数据库
MySQL原理简介—12.MySQL主从同步
本文介绍了四种为MySQL搭建主从复制架构的方法:异步复制、半同步复制、GTID复制和并行复制。异步复制通过配置主库和从库实现简单的主从架构,但存在数据丢失风险;半同步复制确保日志复制到从库后再提交事务,提高了数据安全性;GTID复制简化了配置过程,增强了复制的可靠性和管理性;并行复制通过多线程技术降低主从同步延迟,保证数据一致性。此外,还讨论了如何使用工具监控主从延迟及应对策略,如强制读主库以确保即时读取最新数据。
MySQL原理简介—12.MySQL主从同步
|
5月前
|
监控 关系型数据库 MySQL
Flink CDC MySQL同步MySQL错误记录
在使用Flink CDC同步MySQL数据时,常见的错误包括连接错误、权限错误、表结构变化、数据类型不匹配、主键冲突和
293 17
|
6月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
453 3
|
6月前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
242 3
|
6月前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
75 0
|
3月前
|
SQL 分布式计算 Serverless
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
|
10月前
|
机器学习/深度学习 人工智能 专有云
人工智能平台PAI使用问题之怎么将DLC的数据写入到另一个阿里云主账号的OSS中
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。