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
相关推荐
xiep143833351026 分钟前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
敲上瘾32 分钟前
Linux系统cgroups资源精细化控制基础
linux·测试工具·docker·压力测试·cgroups
Java小白程序员1 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
老虎06271 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle
伊成3 小时前
Docker 部署 Nginx 完整指南
nginx·docker·容器
爱掘金的土拨鼠3 小时前
国产化dm数据库锁表解锁
数据库
落日漫游4 小时前
K8s核心组件全解析
运维·docker·运维开发
庖丁解java4 小时前
N个Utils
数据库
Mr. zhihao4 小时前
SQL LEFT JOIN 与 WHERE 条件的隐藏坑
数据库·sql
2301_793086874 小时前
Redis 04 Reactor
数据库·redis·缓存