docker 部署的mariadb数据库备份还原方案

docker部署下的mariadb数据库备份还原方案

背景:在使用docker部署的mariadb时,我们会将容器内的数据卷挂载到宿主机上,做简单的备份,容器在正常运行和停止的情况下,能快速创建mariadb的镜像,加载之前挂载的数据卷,但有时候mariadb容器可能会崩溃,导致挂载出来的数据卷可能会损坏,且难以修复,这就需要我们经常对mariadb中的数据做定期备份操作,避免出现一些突发情况导致数据库数据丢失问题。

一、方案设计

逻辑备份VS物理备份

逻辑备份:由恢复数据所需的SQL语句组成,例如CREATE DATABASE、CREATE TABLE和INSERT。

物理备份:物理备份是通过复制单个数据文件或目录来执行的。

主要区别如下:

  1. 逻辑备份更灵活,因为数据可以在其他硬件配置、MariaDB版本甚至另一个DBMS上恢复,而物理备份不能在显著不同的硬件、不同的DBMS,甚至可能是不同的MariaDB版本上导入。

  2. 逻辑备份可以在数据库和表级别执行,而物理数据库是目录和文件级别。在MyISAM和InnoDB存储引擎中,每个表都有一个等价的文件集。在MariaDB 5.5之前的版本中,默认情况下,很多InnoDB表都存储在同一个文件中,在这种情况下,不可能通过表进行备份。参见innodb_file_per_table)。

  3. 逻辑备份的大小比同等的物理备份大。

  4. 与同等的物理备份相比,逻辑备份在备份和恢复方面需要更多的时间。

注意:日志文件和配置文件不是逻辑备份的一部分

结论

1、选择逻辑备份

2、备份周期一天两次 中午12点30一次, 晚上0点30分一次 ,通过shell脚本定时执行

大致流程如下:

具体的备份还原脚本如下:

备份操作:

1、创建脚本

# 脚本路径
vim /usr/local/application/docker/scs-projects/mariadb_backup.sh
# 日志路径
touch /usr/local/application/docker/scs-projects/mariadb_backup.log

脚本内容如下

#!/bin/bash

echo "------------------------开始对mariadb进行备份 开始时间是`date '+%Y-%m-%d %H:%M:%S'`------------------------"

# 密码注意切换
docker exec -i mariadb sh -c 'exec mysqldump  -uroot -p"$MARIADB_ROOT_PASSWORD" --all-databases ' > /usr/local/application/mariadb/backup/all-databases.sql

tar -zcvf   /usr/local/application/mariadb/backup/$(date "+%Y_%m_%d_%H_%M_%S").tar.gz /usr/local/application/mariadb/backup/all-databases.sql

# 删除超过一个月的备份文件
find /usr/local/application/mariadb/backup/ -mtime +31 -type f -name "*" -exec rm -rf {} \;

echo "------------------------mariadb进行备份结束 结束时间是`date '+%Y-%m-%d %H:%M:%S'`------------------------"

赋予脚本可执行权限

chmod +x /usr/local/application/docker/scs-projects/mariadb_backup.sh

2、将脚本加入定时任务

crontab -e

内容如下:

30 12 * * * sh /usr/local/application/docker/scs-projects/mariadb_backup.sh >> /usr/local/application/docker/scs-projects/mariadb_backup.log


30 0 * * * sh /usr/local/application/docker/scs-projects/mariadb_backup.sh >> /usr/local/application/docker/scs-projects/mariadb_backup.log
还原操作
# 进入压缩文件所在路径
 # 解压
tar zxvf 文件名

 # 还原即可
 docker exec -i mariadb1 sh -c 'exec mysql -uroot -p"$MARIADB_ROOT_PASSWORD"' < all-databases.sql

posted on 2022-08-09 14:07  _掌心  阅读(661)  评论(0编辑  收藏  举报