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
相关推荐
羑悻的小杀马特9 分钟前
从零搭建群晖私有影音库:NasTool自动化追剧全流程拆解与远程访问协议优化实践
运维·数据库·自动化
TDengine (老段)2 小时前
杨凌美畅用 TDengine 时序数据库,支撑 500 条产线 2 年历史数据追溯
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
葛小白15 小时前
C#数据类型:string简单使用
服务器·数据库·c#
污斑兔5 小时前
MongoDB的$sample是啥?
数据库·mongodb
..Move...6 小时前
快速搭建Docker私有仓库指南
运维·docker·容器
马丁的代码日记7 小时前
MySQL InnoDB 行锁与死锁排查实战演示
数据库·mysql
jiuri_12158 小时前
Docker使用详解:在ARM64嵌入式环境部署Python应用
python·docker·容器
拍客圈8 小时前
数据主站+副站做的设置
数据库
计算机学长felix8 小时前
基于SpringBoot的“面向校园的助力跑腿系统”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·后端
williamdsy8 小时前
【Docker】[特殊字符] Docker 部署完全指南 - 从本地开发到云服务器
服务器·docker·开发部署流程