使用Docker在Linux上定时备份MySQL数据库

数据库 MySQL Linux
在Linux上运行MySQL容器后,为了保证数据的安全性,我们可以设置自动备份任务,采取每周全量备份、每天增量备份的方式。以下是一篇详细的实现指南,涵盖了备份方式的选择、脚本编写及定时任务配置。

在Linux上运行MySQL容器后,为了保证数据的安全性,我们可以设置自动备份任务,采取每周全量备份、每天增量备份的方式。以下是一篇详细的实现指南,涵盖了备份方式的选择、脚本编写及定时任务配置。

1.备份方式概述

  • 每周全量备份:备份整个数据库内容,通常选择周日。
  • 每天增量备份:仅备份每天新增或修改的数据,相较全量备份节省存储空间和时间。

2.运行环境要求

确保系统具备以下条件:

  • Docker:已安装,并确保MySQL在Docker容器中运行。
  • crontab:用于定时任务调度。

3.编写备份脚本

创建一个备份脚本,包含全量和增量备份逻辑。

  • 创建目录:用于存储备份文件。建议如下结构:

/backup/mysql/
├── full/           # 全量备份文件夹
└── incremental/    # 增量备份文件夹

可以用以下命令创建这些文件夹:

mkdir -p /backup/mysql/full
mkdir -p /backup/mysql/incremental
  • 编写备份脚本(mysql_backup.sh)

新建文件 /backup/mysql/mysql_backup.sh,内容如下:


#!/bin/bash

# 配置部分
CONTAINER_NAME="your_mysql_container"              # MySQL容器名称
BACKUP_DIR="/backup/mysql"                         # 备份存储根目录
FULL_BACKUP_DIR="$BACKUP_DIR/full"                 # 全量备份文件夹
INCREMENTAL_BACKUP_DIR="$BACKUP_DIR/incremental"   # 增量备份文件夹
DATE=$(date +"%Y%m%d")

# 保留的备份数量
MAX_BACKUPS=10

# 每周日进行全量备份
if [[ $(date +%u) -eq 7 ]]; then
    echo "开始全量备份..."
    BACKUP_FILE="$FULL_BACKUP_DIR/mysql_full_$DATE.sql"
    docker exec $CONTAINER_NAME sh -c "mysqldump --all-databases -uroot -pYourPassword" > "$BACKUP_FILE"
    gzip "$BACKUP_FILE"  # 压缩备份文件
    echo "全量备份完成并压缩,存储路径:$BACKUP_FILE.gz"
else
    # 每天增量备份
    echo "开始增量备份..."
    BACKUP_FILE="$INCREMENTAL_BACKUP_DIR/mysql_inc_$DATE.sql"
    docker exec $CONTAINER_NAME sh -c "mysqlbinlog --read-from-remote-server --host=localhost --user=root --password=YourPassword --raw mysql-bin.*" > "$BACKUP_FILE"
    gzip "$BACKUP_FILE"  # 压缩备份文件
    echo "增量备份完成并压缩,存储路径:$BACKUP_FILE.gz"
fi

# 清理多余备份,保留最近的10个备份
cleanup_backups() {
    local BACKUP_FOLDER=$1
    local BACKUP_FILES_COUNT=$(ls -1 "$BACKUP_FOLDER" | wc -l)

    if (( BACKUP_FILES_COUNT > MAX_BACKUPS )); then
        local FILES_TO_DELETE=$((BACKUP_FILES_COUNT - MAX_BACKUPS))
        echo "超过 $MAX_BACKUPS 份备份,开始删除旧备份..."
        ls -1tr "$BACKUP_FOLDER" | head -n $FILES_TO_DELETE | while read -r FILE; do
            rm -f "$BACKUP_FOLDER/$FILE"
            echo "已删除过期备份:$BACKUP_FOLDER/$FILE"
        done
    fi
}

# 执行清理操作
cleanup_backups "$FULL_BACKUP_DIR"
cleanup_backups "$INCREMENTAL_BACKUP_DIR"

注意将 your_mysql_container 替换为实际MySQL容器名称,YourPassword 替换为实际的MySQL root用户密码。

  • 赋予脚本执行权限

chmod +x /backup/mysql/mysql_backup.sh

4. 设置定时任务

使用 crontab 来实现自动定时备份。通过 crontab 设置如下计划:

• 每天的凌晨2点执行备份脚本。

编辑 crontab

打开 crontab 编辑器:

crontab -e

添加以下行配置定时任务:

0 2 * * * /backup/mysql/mysql_backup.sh >> /backup/mysql/backup.log 2>&1

5. 验证备份是否成功

可以手动执行脚本:

/backup/mysql/mysql_backup.sh

在 /backup/mysql/full 和 /backup/mysql/incremental 中检查是否生成了对应的 .sql 文件。每日备份日志存储在 /backup/mysql/backup.log,可以通过 tail -f /backup/mysql/backup.log查看任务执行情况。

6.恢复数据

  • 恢复全量备份:直接将最新的全量备份文件导入MySQL。
  • 应用增量备份:先导入全量备份,然后逐个执行增量备份文件。

通过以上步骤,我们便可以在Docker上实现MySQL的每日增量备份和每周全量备份,确保数据的持续性和安全性。

责任编辑:华轩 来源: 微技术之家
相关推荐

2021-09-22 09:55:20

LinuxMySQL数据库

2018-06-07 09:22:16

LinuxMysql备份

2020-10-23 18:45:31

NavicatMySQL数据库

2019-07-25 18:57:36

Linux数据库自动备份

2010-05-20 16:57:10

MySQL数据库

2011-08-22 16:03:30

linuxVPS备份数据库

2010-06-04 17:49:46

连接MySQL数据库

2023-09-21 09:31:24

MySQL数据库

2011-09-01 15:26:51

QtMysql数据库

2013-05-24 13:24:46

Mysql数据库自动备份

2017-06-19 08:13:00

Sequel ProMySQL数据库

2018-11-02 08:10:58

Linuxsystemd定时器

2018-02-26 08:14:20

LinuxDocker容器

2010-08-17 14:38:46

备份DB2数据库

2011-03-31 14:34:46

cactimysql备份

2011-03-30 13:57:41

MySQL数据库自动备份

2019-03-01 13:40:01

MySQL数据库备份案例

2010-06-04 18:12:17

MySQL 数据库启动

2011-06-10 10:31:57

QT mysql linux

2010-05-20 16:13:55

点赞
收藏

51CTO技术栈公众号