脚本:Docker 数据库 全量备份后复制文件到另外服务器

#!/bin/bash
# 容器名称  容器ID,容器名称都行,建议使用id,不会被更改
CONTAINER="mysql"
# 数据库账户
USERNAME=""
# 数据库密码
PASSWORD=""
# 日期
DATE=$(date +%Y%m%d%H)
# 数据库备份根目录
BACKUP_DIR="/home/mysqlBak"
# 备份压缩包文件
BACKUP_ZIP_PATH="${BACKUP_DIR}/${DATE}".zip
# 备份数据库
DATABASES=$(docker exec -i ${CONTAINER} mysql -u${USERNAME} -p${PASSWORD} -e "show databases" | grep -Ev "information_schema|performance_schema")
# 备份数据保留天数
CLEAN_DAY=5

# 远程服务IP
REMOTE_IP=""
# 远程服务用户名
REMOTE_USERNAME=""
# 远程服务密码
REMOTE_PASSWORD=""
# 远程服务目录
REMOTE_FOLDER="/home/remoteSqlBak"

#如果文件夹不存在则创建
if [ ! -d "$BACKUP_DIR" ]; then
mkdir -p $BACKUP_DIR
fi

#循环数据库进行备份
for DB in  $DATABASES
do
  DB_PATH=${BACKUP_DIR}/"${DB}_${DATE}".sql
  docker exec -i ${CONTAINER} mysqldump -u${USERNAME} -p${PASSWORD} ${DB} > ${DB_PATH}
  # 将文件压缩进zip
  zip -m ${BACKUP_ZIP_PATH} ${DB_PATH}
done
echo "done"

#从本地复制到远程
sshpass -p ${REMOTE_PASSWORD} scp ${BACKUP_ZIP_PATH} ${REMOTE_USERNAME}@${REMOTE_IP}:${REMOTE_FOLDER}

#删除N天之前的备份
find ${BACKUP_DIR} -name "*.zip" -type f -mtime +${CLEAN_DAY} -exec rm {} \; > /dev/null 2>&1

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值