docker部署的mysql怎么执行备份?

选择适合自己的,以下是几种版本的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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值