当前位置: 首页 > news >正文

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 下载备份文件,执行恢复测试,确保备份有效性。

http://www.jsqmd.com/news/170692/

相关文章:

  • 秃鹰优化算法BES优化广义神经网络GRNN实现多特征拟合预测
  • nvm终极优化指南:释放磁盘空间的高效技巧
  • Hunyuan-GameCraft技术解析:消费级显卡驱动的高动态游戏视频生成指南
  • 不会SPSS、不懂Python,也能做“真数据分析”?揭秘毕业论文里的数据困局与破局新工具
  • 污水厂工艺仿真系统哪家公司好、推荐品牌?如何优化工艺? - 品牌推荐大师
  • 使用Markdown数学公式书写Transformer注意力机制
  • 多功能酒店小程序源码系统,集成订餐、商城、分销于一体
  • 终极指南:获取Microsoft Visio 2010完整版,打造专业流程图
  • transformer模型详解之位置编码Positional Encoding实现
  • 揭秘DevYouTubeList:普通人也能参与的开发者视频宝库治理指南
  • Development Containers声明式配置:打造团队高效协作的标准化开发环境
  • 2025年度OI总结
  • Rallly调度系统架构解析:tRPC全栈类型安全如何重塑协作体验
  • 如何用C语言将AI模型塞进浏览器?WASM黑科技全解析
  • AsyncReactiveProperty:让Unity异步状态管理变得简单高效
  • 终极指南:如何用Awesome-Balatro打造你的专属扑克roguelike世界
  • SSH免密码登录TensorFlow 2.9镜像提升运维效率
  • [学习笔记]流匹配(Flow Matching)
  • 影视AI革命:Qwen-Image-Edit 2509与next-scene LoRA如何重构分镜制作流程
  • C17标准中_Generics的高级应用(泛型编程新纪元)
  • Lottie-Web:让设计师的创意在网页上“活“起来
  • Docker exec进入正在运行的TensorFlow 2.9容器
  • 2025年质量好的彩钢岗亭/真石漆岗亭厂家最新实力排行 - 品牌宣传支持者
  • Conda update更新TensorFlow 2.9到最新补丁版本
  • 解密Prompt系列67. 智能体的经济学:从架构选型到工具预算
  • 磁悬浮鼓风机保护轴承厂家推荐 涂层/满装陶瓷球轴承/跌落次数10次以上/718/719/618/619保护轴承源头厂家 - 小张666
  • NYC插件系统实战指南:构建企业级代码覆盖率分析平台
  • 智能文档处理技术新突破:腾讯混元POINTS-Reader如何重构市场格局
  • PE Tools 终极逆向工程工具:从零开始掌握 Windows 可执行文件分析
  • 2025年温湿度振动三综合试验箱直销厂家权威推荐榜单:温湿振动三综合试验箱/大型三综合试验箱/大型三综合试验箱/快速温变综合试验箱/环境三综合试验箱源头厂家精选 - 品牌推荐官