选择适合自己的,以下是几种版本的mysql容器备份
版本一:
路径和用户名密码自行修改,脚本文件名字自行创建
#!/bin/bash
TIMESTAMP=$(date +%Y%m%d%H%M%S)
BACKUP_DIR="/bak/quan_mysql" #备份路径
FULL_BACKUP_FILE="$BACKUP_DIR/full_backup_$TIMESTAMP.sql.gz" #以当前时间为名的备份后的文件
sudo mkdir -p $BACKUP_DIR
sudo docker exec xmd-mysql mysqldump --single-transaction -uroot -pmy_password --all-databases | gzip > $FULL_BACKUP_FILE
#删除180天前的文件
sudo find "$BACKUP_DIR" -name "full_backup_*.gz" -type f -mtime +180 -exec rm {} \;
要恢复数据,首先需要有一个可用的备份文件。你可以找到之前创建的备份文件,并使用以下命令进行恢复:
#!/bin/bash
BACKUP_FILE="/bak/quan_mysql/full_backup_20230904231401.sql.gz"
gunzip < $BACKUP_FILE | docker exec -i xmd-mysql mysql -uroot -pmy_password
版本二:
mysql全备执行脚本,亲测有效
vi jb.sh
#!/bin/bash
TIMESTAMP=$(date +%Y%m%d%H%M%S)
BACKUP_DIR="/data/backup" #存放路径
BACKUP_FILE="$BACKUP_DIR/backup_$TIMESTAMP"
USER="root"
PASSWORD="数据库密码"
CTNAME="mysql"
#CTNAME=`docker ps | grep mysql | awk '{print $1}'`
#find "$BACKUP_DIR" -name "backup_*" -type f -mtime +180
docker exec $CTNAME mysqldump -u$USER -p$PASSWORD --single-transaction --all-databases > $BACKUP_FILE.sql 2> $BACKUP_FILE.log
#master-data=2
gzip -n $BACKUP_FILE.sql