MySQL 定时逻辑备份

文章目录

配置密码

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

编写备份脚本

复制代码
cat > /usr/local/bin/mysql_dump.sh <<"EOF"
#!/bin/bash

DATE=$(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.4
  MYSQL_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 ]; }; then
    echo "Detected MySQL version $MYSQL_VERSION, using --source-data=2"
    DATA_OPT="--source-data=2"
  else
    echo "Detected MySQL version $MYSQL_VERSION, using --master-data=2"
    DATA_OPT="--master-data=2"
  fi

  mysqldump --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 ]; then
    echo "=== Backup SUCCESSFUL at $(date) ==="
  else
    echo "=== Backup FAILED at $(date) ==="
  fi

  # 清理7天前的旧备份和日志
  find "$LOG_DIR" -name "backup_*.log" -mtime +7 -delete
  find "$BACKUP_DIR" -name "all_backup_*.sql.gz" -mtime +7 -delete

} >> "$LOG_FILE" 2>&1

EOF

配置权限

复制代码
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"
相关推荐
NineData3 小时前
NineData发布 Oracle 到 MySQL 双向实时复制,助力去 O 战略与数据回流
mysql·阿里云·oracle·ninedata·数据库迁移·数据复制·双向复制
皆过客,揽星河4 小时前
mysql初学者练习题(从基础到进阶,相关数据sql脚本在最后)
数据库·sql·mysql·oracle·mysql基础练习·mysql基础语法·数据库练习题
AI小小怪6 小时前
在linux下使用MySQL常用的命令集合
linux·数据库·mysql·oracle
XYiFfang9 小时前
【mysql】SQL自连接实战:查询温度升高的日期
数据库·sql·mysql
四季豆豆豆12 小时前
办公任务分发项目 laravel vue mysql 第一章:核心功能构建 API
vue.js·mysql·laravel
一个CCD12 小时前
MySQL主从复制之进阶延时同步、GTID复制、半同步复制完整实验流程
android·mysql·adb
R瑾安12 小时前
mysql集群部署(Mysql Group Replication)
数据库·mysql·wpf
没刮胡子12 小时前
mysql分页SQL
数据库·sql·mysql
高级测试工程师欧阳13 小时前
SQLint3 模块如何使用
数据库·python·mysql·oracle
小池先生13 小时前
docker中的mysql变更宿主机映射端口
android·mysql·docker