容器化MariaDB/Mysql实现定时备份

#编程技术 2024-04-21 10:10:00 | 全文 764 字,阅读约需 2 分钟 | 加载中... 次浏览

👋 相关阅读


前段时间购买了绿云的 VPS,刚用了一个月就遇到主机上问题,导致数据全部丢失,幸好上边没有放什么重要的东西,但是也提醒了自己备份的重要性

目前服务器采用的是全部 Docker 容器化的方式,本站以及数据库都是运行在单独的 docker 容器中,为了以防万一,觉得还是需要定时的全量备份比较好

备份方案

目前想到的方案是采取 mysqldump 工具进行备份的方式,所以需要构建一个单独的容器,在容器这个容器中使用 mysqldump 命令连接另一个容器的 mariadb 进行备份

编写备份脚本

新建一个备份目录,比如 backupdata

在 backupdata 目录下,创建一个 backup_script.sh 文件,内容如下:

#!/bin/bash

# 获取环境变量(-后边的内容为未获取到对应变量时的默认值)
MYSQL_HOST=${MYSQL_HOST:-"192.168.0.200"}
MYSQL_PORT=${MYSQL_PORT:-"3306"}
MYSQL_USER=${MYSQL_USER:-"demo"}
MYSQL_PASSWORD=${MYSQL_PASSWORD:-"demo"}
MYSQL_DATABASE="dbname"
BACKUP_DIR="${BACKUP_DIR:-"/backup"}"

# 创建备份目录(如果不存在)
mkdir -p "$BACKUP_DIR"

# 设置备份文件名称(包含时间戳)
BACKUP_FILENAME="$BACKUP_DIR/blog_$(date +'%Y%m%d%H%M%S').sql.gz"

# 执行mysqldump命令并压缩备份文件
mysqldump -h $MYSQL_HOST -P $MYSQL_PORT -u$MYSQL_USER -p$MYSQL_PASSWORD --single-transaction $MYSQL_DATABASE | gzip > $BACKUP_FILENAME

echo "Database backup has been created at $BACKUP_FILENAME"

构建容器镜像

在 backupdata 目录下,创建一个 Dockerfile 文件:

# 使用包含 mysql-client 和 bash 的基础镜像
FROM alpine:latest

# 替换为阿里云的 Alpine 镜像源(如果需要)
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories

# 更新包索引并安装 mysqldump 与 bash
RUN apk update && apk add --no-cache mysql-client bash coreutils

# 设置环境变量(替换为你的docker中数据库的信息)
ENV MYSQL_HOST="192.168.0.200"
ENV MYSQL_PORT="3306"
ENV MYSQL_USER="demo"
ENV MYSQL_PASSWORD="demo"
ENV MYSQL_DATABASE="dbname"
ENV BACKUP_DIR="/backup"

# 将备份脚本复制到容器内
COPY backup_script.sh /usr/local/bin/backup_script.sh
RUN chmod +x /usr/local/bin/backup_script.sh

# 在容器启动时执行备份脚本
CMD ["/usr/local/bin/backup_script.sh"]

构建容器&启动容器

容器内部的备份目录设置的是 /backup ,所以我这里将宿主机的 /data/backup 映射到容器的 /backup 目录,当备份完成后宿主机的 /data/backup 就会看到备份的文件

# 构建容器
docker build -t db-backup-image .
# 启动容器
docker run -d \
  --env MYSQL_HOST=192.168.0.200 \
  --env MYSQL_PORT=3306 \
  -v /data/backup:/backup \
  db-backup-image

执行完成容器会自动退出,此时可以查看备份目录 backupdata 下是否存在备份的数据库文件

设置 Cron 定时任务

通过 docker ps -a 命令,我们可以拿到构建容器的容器 id,通过执行 docker start 容器id 命令就可以执行备份了

crontab -e

# 在后面添加一行:

0 1 * * * docker restart xxx(xxx替换为你的容器ID)

保存后,将会在每天的凌晨一点执行备份

VIA

容器化MariaDB/Mysql定时备份实现 - 珂泽小站 https://www.kezez.com/archives/278.html

·




×