news 2026/6/20 7:36:35

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/10 1:53:08

借助GitHub Actions自动同步TensorFlow 2.9镜像开发进度

借助GitHub Actions自动同步TensorFlow 2.9镜像开发进度 在现代AI工程实践中,一个常见的痛点是:团队成员反复花费数小时配置本地环境,却仍因版本差异导致“在我机器上能跑”的尴尬局面。尤其当项目依赖 TensorFlow 这类大型框架时&#xff0c…

作者头像 李华
网站建设 2026/6/19 8:31:01

Next AI Draw.io:用自然语言指令生成专业级技术图表

Next AI Draw.io:用自然语言指令生成专业级技术图表 【免费下载链接】next-ai-draw-io 项目地址: https://gitcode.com/GitHub_Trending/ne/next-ai-draw-io 在技术文档编写和系统架构设计中,图表可视化是传达复杂概念的关键工具。Next AI Draw.…

作者头像 李华
网站建设 2026/6/13 5:17:40

transformer模型详解之中文NER任务实战

Transformer模型详解之中文NER任务实战 在智能客服、医疗信息抽取和金融风险监控等实际场景中,命名实体识别(NER)是构建知识图谱与实现自动化决策的关键一环。尤其对于中文文本而言,由于缺乏天然的词边界、存在大量未登录词以及复…

作者头像 李华
网站建设 2026/6/10 3:09:58

5步精通ECharts Timeline:打造动态数据故事的神器

5步精通ECharts Timeline:打造动态数据故事的神器 【免费下载链接】echarts ECharts 是一款基于 JavaScript 的开源可视化库,提供了丰富的图表类型和交互功能,支持在 Web、移动端等平台上运行。强大的数据可视化工具,支持多种图表…

作者头像 李华
网站建设 2026/6/7 4:29:01

Tinyhttpd微型Web服务器:5分钟快速部署与代码解析指南

Tinyhttpd微型Web服务器:5分钟快速部署与代码解析指南 【免费下载链接】Tinyhttpd Tinyhttpd 是J. David Blackstone在1999年写的一个不到 500 行的超轻量型 Http Server,用来学习非常不错,可以帮助我们真正理解服务器程序的本质。官网:http:…

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

Objectron:开启3D物体检测新纪元的开源利器

Objectron:开启3D物体检测新纪元的开源利器 【免费下载链接】Objectron 项目地址: https://gitcode.com/gh_mirrors/ob/Objectron 在人工智能蓬勃发展的今天,3D物体检测正成为计算机视觉领域的重要突破点。Google Research推出的Objectron项目&a…

作者头像 李华