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

MySQL 定时逻辑备份

文章目录

  • 配置密码
  • 编写备份脚本
  • 配置权限
  • 定时任务配置
  • 检查效果
  • 如果不想保留明文密码
    • 手工配置备份密码
    • 修改备份命令

配置密码

cat >> /root/.my.cnf <<"EOF"
[client]
user=root
password=YourPassword
EOF

编写备份脚本

cat > /usr/local/bin/mysql_dump.sh <<"EOF"
#!/bin/bashDATE=$(date +%F_%H-%M-%S)
BACKUP_DIR="/data/mysql_backups"
LOG_DIR="/var/log/mysql_backup"
LOG_FILE="$LOG_DIR/backup_$DATE.log"mkdir -p "$BACKUP_DIR" "$LOG_DIR"{echo "=== MySQL Backup started at $(date) ==="# 获取 MySQL 主版本号,例如 8.0、8.4MYSQL_VERSION=$(mysql -V | awk '{print $3}' | cut -d. -f1,2)# 判断是否使用 source-data(MySQL >= 8.4)MAJOR=$(echo "$MYSQL_VERSION" | cut -d. -f1)MINOR=$(echo "$MYSQL_VERSION" | cut -d. -f2)if [ "$MAJOR" -ge 9 ] || { [ "$MAJOR" -eq 8 ] && [ "$MINOR" -ge 4 ]; }; thenecho "Detected MySQL version $MYSQL_VERSION, using --source-data=2"DATA_OPT="--source-data=2"elseecho "Detected MySQL version $MYSQL_VERSION, using --master-data=2"DATA_OPT="--master-data=2"fimysqldump --defaults-extra-file=/root/.my.cnf \--all-databases \--single-transaction \--host=127.0.0.1 \$DATA_OPT \--routines \--events \--triggers \| gzip > "$BACKUP_DIR/all_backup_$DATE.sql.gz"if [ $? -eq 0 ]; thenecho "=== Backup SUCCESSFUL at $(date) ==="elseecho "=== Backup FAILED at $(date) ==="fi# 清理7天前的旧备份和日志find "$LOG_DIR" -name "backup_*.log" -mtime +7 -deletefind "$BACKUP_DIR" -name "all_backup_*.sql.gz" -mtime +7 -delete} >> "$LOG_FILE" 2>&1EOF

配置权限

chmod +x /usr/local/bin/mysql_dump.sh

定时任务配置

cat >> /etc/crontab <<"EOF"
0 1 * * * root flock -xn /tmp/mysq_dump.lock -c /usr/local/bin/mysql_dump.sh
EOF

注意这里的 root 别忘记了, 我实际测试的时候发现没有 root 就没有执行生效

检查效果

  1. 手动执行
flock -xn /tmp/mysq_dump.lock -c /usr/local/bin/mysql_dump.sh

2.修改定时任务触发时间验证

如果不想保留明文密码

手工配置备份密码

mysql_config_editor set --login-path=backup --user=root  --password

修改备份命令

将 
mysqldump --defaults-extra-file=/root/.my.cnf \--all-databases \--single-transaction \$DATA_OPT \--routines \--events \--triggers \| gzip > "$BACKUP_DIR/all_backup_$DATE.sql.gz"
改为 
mysqldump  mysqldump --login-path=backup \--all-databases \--single-transaction \$DATA_OPT \--routines \--events \--triggers \| gzip > "$BACKUP_DIR/all_backup_$DATE.sql.gz"

相关文章:

  • CI/CD (持续集成/持续部署) GitHub Actions 自动构建
  • GitLab-CI将项目Wiki自动部署到文档中心
  • 卷积神经网络(CNN)深度讲解
  • 【HarmonyOS5】DevEco Studio 预览器与模拟工具详解
  • 基于文本挖掘与情感分析的B站《唐探1900》弹幕研究
  • 使用Cursor生成需求文档+UI设计图
  • 【微服务】SpringBoot 对接飞书审批流程使用详解
  • Python GDAL 库离线安装
  • NTFS0x90属性和0xa0属性和0xb0属性的一一对应关系是index_entry中的index_node中VCN和runlist和bitmap
  • Mybatis框架的构建(IDEA)
  • 【C++】21. 红黑树的实现
  • JWT与布隆过滤器结合使用指南
  • C++编程单例模式详细解释---模拟一个网络配置管理器,负责管理和分发网络连接参数
  • 分布式缓存:三万字详解Redis
  • 华为OD机试真题—— 矩阵匹配(2025B卷:200分)Java/python/JavaScript/C/C++/GO最佳实现
  • Redis数据安全分析
  • 上海医日健集团物联网专利技术领跑智慧药房赛道
  • Lua 脚本在 Redis 中的运用-24 (使用 Lua 脚本实现原子计数器)
  • (27)运动目标检测 之 分类(如YOLO) 数据集自动划分
  • 大语言模型在软件工程中的应用、影响与展望
  • 盐城网站建设官网/网站如何优化关键词排名
  • 交易平台网站开发教程百度云/广州seo公司如何
  • 郴州市高中阶段招生录取系统/seo技术培训中心
  • 如何在台湾做企业网站/微信如何引流推广精准加人
  • 电影网站如何做采集/日本今日新闻头条
  • 买了域名和空间怎么做网站/谷歌广告投放