news 2026/6/15 18:00:52

Linux 定时备份 MySQL 并推送 Gitee

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux 定时备份 MySQL 并推送 Gitee

核心准备工作

环境依赖
确保服务器已安装以下工具:

  • Docker
  • Git
  • mailx(用于邮件通知)
  • dos2unix(解决脚本格式问题)

Gitee 配置
创建私有仓库(如mysql_backup),避免数据泄露。

SSH 免密配置

# 生成 SSH 密钥(一路回车)ssh-keygen-trsa-C"your_email@example.com"# 复制公钥内容cat~/.ssh/id_rsa.pub# Gitee 配置:头像→设置→SSH公钥→粘贴公钥保存# 测试免密连接ssh-Tgit@gitee.com

初始化本地 Git 仓库

mkdir-p/opt/mysql_backup/{backups,gitee_backup}cd/opt/mysql_backup/gitee_backupgitinitgitremoteaddorigin git@gitee.com:your_username/mysql_backup.git# 配置 Git 用户名和邮箱gitconfig--globaluser.name"Your Name"gitconfig--globaluser.email"your_email@example.com"

备份脚本优化

创建/opt/mysql_backup/backup.sh,支持以下功能:

  • 指定库或全库备份
  • 失败自动重试
  • 邮件通知
  • 自动压缩和清理旧备份
#!/bin/bashset-e# ===== 配置区 =====CONTAINER_NAME="mysql"# Docker MySQL 容器名MYSQL_USER="root"MYSQL_PASSWORD="1234"# MySQL 密码BACKUP_MODE="all"# 备份模式:all(全库)或指定库名BACKUP_DIR="/opt/mysql_backup/backups"GIT_REPO_DIR="/opt/mysql_backup/gitee_backup"KEEP_BACKUPS=10# 保留最近10个备份MAX_RETRIES=3# 失败重试次数RETRY_DELAY=60# 重试间隔(秒)EMAIL_TO="your_email@example.com"# 通知邮箱DATE=$(date+"%Y%m%d_%H%M%S")BACKUP_FILE="${BACKUP_DIR}/mysql_${DATE}.sql"BACKUP_FILE_GZ="${BACKUP_FILE}.gz"LOG_FILE="/opt/mysql_backup/backup_${DATE}.log"# ===== 配置结束 =====# 日志函数log(){echo"[$(date'+%F %T')]$1"|tee-a${LOG_FILE}}# 邮件通知函数send_email(){localsubject="$1"localbody="$2"echo-e"${body}"|mailx-s"${subject}"${EMAIL_TO}}# 失败重试函数retry(){localn=1localmax=${MAX_RETRIES}localdelay=${RETRY_DELAY}whiletrue;do"$@"&&break||{if[[${n}-lt${max}]];thenlog"失败重试${n}/${max}${delay}秒后重试..."((n++))sleep${delay}elselog"达到最大重试次数${max},任务失败"return1fi}done}# 主备份流程log"开始 MySQL 备份任务..."mkdir-p${BACKUP_DIR}# 选择备份模式if[["${BACKUP_MODE}"=="all"]];thenBACKUP_CMD="mysqldump -u${MYSQL_USER}-p${MYSQL_PASSWORD}--all-databases --single-transaction"elseBACKUP_CMD="mysqldump -u${MYSQL_USER}-p${MYSQL_PASSWORD}${BACKUP_MODE}--single-transaction"fi# 执行备份(带重试)if!retrydockerexec${CONTAINER_NAME}${BACKUP_CMD}>${BACKUP_FILE};thenlog"数据库备份失败!"send_email"MySQL备份失败""备份时间:$(date)\n失败日志:${LOG_FILE}"exit1fi# 压缩备份文件gzip${BACKUP_FILE}log"备份完成:${BACKUP_FILE_GZ}"# 清理旧备份ls-tp${BACKUP_DIR}/*.sql.gz|grep-v'/$'|tail-n+$((KEEP_BACKUPS+1))|xargs-I{}rm--{}log"已清理旧备份,保留最近${KEEP_BACKUPS}个"# 推送 Gitee(带重试)if!retrybash-c"cd${GIT_REPO_DIR}&& cp${BACKUP_FILE_GZ}. && git add . && git commit -m 'Backup${DATE}' && git push origin master";thenlog"推送 Gitee 失败!"send_email"MySQL备份推送失败""备份成功但推送失败,日志:${LOG_FILE}"exit1filog"推送 Gitee 成功!"send_email"MySQL备份成功""备份文件:${BACKUP_FILE_GZ}\n备份时间:$(date)"log"备份任务全部完成!"

脚本修复与权限配置

# 修复 Windows 格式问题dos2unix /opt/mysql_backup/backup.sh# 添加执行权限chmod+x /opt/mysql_backup/backup.sh# 手动测试脚本/opt/mysql_backup/backup.sh

定时任务设置

# 编辑 crontabcrontab-e# 每天 12 点和 0 点备份012* * * /opt/mysql_backup/backup.sh>>/opt/mysql_backup/backup.log2>&100* * * /opt/mysql_backup/backup.sh>>/opt/mysql_backup/backup.log2>&1# 查看定时任务crontab-l

关键问题排查

备份文件数据量少
检查BACKUP_MODE是否设置为all,确保启用全库备份。

推送 Gitee 报 404
检查 Git 远程地址是否正确:

gitremote set-url origin git@gitee.com:your_username/mysql_backup.git

SSH 免密失败
确保私钥权限正确:

chmod600~/.ssh/id_rsa

优化建议

安全优化
使用~/.my.cnf存储 MySQL 凭据,避免明文密码:

[mysqldump] user=root password=1234

修改备份命令为:

BACKUP_CMD="mysqldump --defaults-extra-file=/root/.my.cnf --single-transaction${BACKUP_MODE}"

性能优化
添加--single-transaction参数避免锁表,适合 InnoDB 数据库。

验证优化
定期从 Gitee 下载备份文件,执行恢复测试,确保备份有效性。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 13:10:49

Readest自托管同步终极指南:快速打造私有阅读数据中枢

Readest自托管同步终极指南:快速打造私有阅读数据中枢 【免费下载链接】readest Readest is a modern, feature-rich ebook reader designed for avid readers offering seamless cross-platform access, powerful tools, and an intuitive interface to elevate yo…

作者头像 李华
网站建设 2026/6/15 11:47:48

【高性能计算专家亲授】:C语言TensorRT低延迟推理优化的12个隐藏技巧

第一章:C语言TensorRT低延迟推理的核心挑战在高性能计算与边缘推理场景中,使用C语言集成TensorRT实现低延迟推理面临多重技术挑战。这些挑战不仅涉及内存管理与数据布局的底层优化,还需应对硬件异构性带来的兼容性问题。内存访问模式的高效控…

作者头像 李华
网站建设 2026/6/15 11:45:16

Jupyter line profiler分析TensorFlow代码性能瓶颈

Jupyter line profiler分析TensorFlow代码性能瓶颈 在深度学习项目中,我们常常遇到这样的情况:模型结构看似合理,数据流程也已打通,但训练速度就是提不上去。GPU利用率长期徘徊在30%以下,每个step耗时远超预期。这时候…

作者头像 李华
网站建设 2026/5/22 9:26:45

AsyncReactiveProperty:让Unity异步状态管理变得简单高效

AsyncReactiveProperty:让Unity异步状态管理变得简单高效 【免费下载链接】UniTask Provides an efficient allocation free async/await integration for Unity. 项目地址: https://gitcode.com/gh_mirrors/un/UniTask 你是否曾经在Unity项目中遇到过这样的…

作者头像 李华
网站建设 2026/6/15 12:53:40

Conda activate提示符修改标识当前TensorFlow环境

Conda环境激活时自定义提示符:精准标识TensorFlow开发上下文 在深度学习项目开发中,一个看似微小却影响深远的痛点常常被忽视——当你打开终端准备训练模型时,如何快速确认当前所处的Python环境是否真的加载了正确的TensorFlow版本&#xff1…

作者头像 李华