数据库备份

容器数据库

[root@localhost mysql.back]# cat backup_mysql.sh 
#!/bin/bash
# 日志文件路径
log_file="/home/mysql.back/logs/backup_mysql.log"

# MySQL 容器信息
CONTAINER_NAME="fosow-biz-mysql"
MYSQL_USER="root"
MYSQL_PASSWORD="root"

# 备份目录
BACKUP_DIR="/home/mysql.back/data"

# 创建带有当前时间戳的备份文件
BACKUP_FILE="$BACKUP_DIR/mysql_backup_$(date +%Y%m%d%H%M%S).sql"

# 在 MySQL 容器内运行 mysqldump 命令备份所有数据库
docker exec $CONTAINER_NAME mysqldump -u$MYSQL_USER -p$MYSQL_PASSWORD --all-databases > $BACKUP_FILE

echo "备份完成: $BACKUP_FILE"

# 删除超过两天的备份文件
find "$BACKUP_DIR" -name "mysql_backup_*" -type f -mtime +2 -delete


物理机数据库

#!/bin/bash
# 日志文件路径
log_file="/home/mysql/logs/backup_mysql.log"

MYSQL_USER="root"
MYSQL_PASSWORD="123qqq...A"

# 备份目录
BACKUP_DIR="/home/mysql/"

# 创建带有当前时间戳的备份文件
BACKUP_FILE="$BACKUP_DIR/mysql_backup_$(date +%Y%m%d%H%M%S).sql"


# 使用 rsync 复制数据到备份目录
mysqldump -u"$MYSQL_USER" -p"$MYSQL_PASSWORD" --all-databases > "$BACKUP_FILE"

# 检查 mysqldump 是否成功
if [ $? -eq 0 ]; then
  echo "备份完成: $BACKUP_FILE" >> "$log_file"
else
  echo "备份失败" >> "$log_file"
fi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值