Docker 下备份 Mariadb 数据库文件

描述

正常来说我们备份脚本,一般都是执行数据库目录下的 ...dump 文件的,但是在镜像中并且运行的容器如何备份?

就是使用容器中的 Mariadb 自带的备份脚本

操作

1、查看我们所有正在运行的容器信息

shell 复制代码
docker ps -a

找到容器的ID

2、然后我们进入到容器

shell 复制代码
docker exec -it 镜像运行的id bash

进来之后,找到 Mariadb 安装的所在目录

shell 复制代码
find -name mariadb

找到目录后,就能看到所对应的备份文件,注意后面的mariadb不是目录!

shell 复制代码
cd /usr/bin/

ls mariadb

mariadb-dump这个就是备份脚本

验证一下脚本是否可用

shell 复制代码
mariadb-dump -uroot -p123456 你的数据库名字 > backup.sql

是有大小的,那么就可以了,记住当前dump脚本的路径。

退出去容器,用docker 的 exec 命令备份试一下

shell 复制代码
docker exec mariadb /usr/bin/mariadb-dump -uroot -p123456 你的数据库名称 > backup.sql

ok,执行成功了,大小的话,数据库数据我有变更,所以大一些。

配合外部的cron定时任务就可以进行定时了

完整的备份脚本

shell 复制代码
#!/bin/bash

# 定义变量
BACKUP_DIR="./data_file"  # 备份存储目录
CONTAINER_NAME="mariadb"           # MariaDB容器名
MYSQL_USER="root"                  # 数据库用户名
MYSQL_PASSWORD="123456"      # 数据库密码
DATABASE_NAME="你数据的名字"      # 要备份的数据库名
DATE=$(date +%Y%m%d_%H%M%S)        # 当前时间格式

# 创建备份目录
mkdir -p $BACKUP_DIR

# 使用 `docker exec` 执行 `mysqldump` 备份
docker exec $CONTAINER_NAME /usr/bin/mariadb-dump -u$MYSQL_USER -p$MYSQL_PASSWORD $DATABASE_NAME > $BACKUP_DIR/${DATABASE_NAME}_${DATE}.sql


# 压缩备份文件(可选)
gzip $BACKUP_DIR/${DATABASE_NAME}_${DATE}.sql

# 删除7天前的旧备份
find $BACKUP_DIR -type f -name "*.sql.gz" -mtime +7 -delete

定时cron命令设置凌晨12点执行一次

运行以下命令编辑当前用户的 cron 任务

shell 复制代码
crontab -e

在打开的文件末尾添加以下行

shell 复制代码
0 0 * * * 你的备份脚本路径/backup-hpc-cloud.sh

检查任务是否添加成功

shell 复制代码
crontab -l

正常会显示

shell 复制代码
0 0 * * * /opt/mariadb_backup.sh
相关推荐
一 乐4 小时前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
hackchen5 小时前
NexusTerminal一款视频移动端的webSSH
docker·云原生·eureka·web-ssh
美林数据Tempodata6 小时前
大模型驱动数据分析革新:美林数据智能问数解决方案破局传统 BI 痛点
数据库·人工智能·数据分析·大模型·智能问数
野槐6 小时前
node.js连接mysql写接口(一)
数据库·mysql
Zzzone6836 小时前
PostgreSQL日常维护
数据库·postgresql
chxii6 小时前
1.13使用 Node.js 操作 SQLite
数据库·sqlite·node.js
冰刀画的圈6 小时前
修改Oracle编码
数据库·oracle
这个胖子不太裤7 小时前
Django(自用)
数据库·django·sqlite
麻辣清汤7 小时前
MySQL 索引类型及其必要性与优点
数据库·mysql
2501_915374358 小时前
Neo4j 图数据库安装教程(2024最新版)—— Windows / Linux / macOS 全平台指南
数据库·windows·neo4j